Algorithme de Risch

Algorithme de Risch

L’algorithme de Risch, dû à Robert Risch (de), est un algorithme destiné aux systèmes de calcul formel, permettant de calculer des primitives, c'est-à-dire de déterminer une fonction, connaissant sa dérivée. L’algorithme transforme ce problème en un problème d'algèbre (ou plus précisément d'algèbre différentielle (en)). Il est basé sur la forme de la fonction à intégrer et sur des méthodes pour intégrer les fonctions rationnelles, les radicaux, les logarithmes, et les exponentielles. Risch, qui développa l'algorithme en 1968, l'a appelé une procédure de décision, parce qu'il est capable de déterminer si une fonction admet une primitive exprimable à l'aide des fonctions élémentaires (et, si c'est le cas, de la déterminer explicitement). L’algorithme de Risch est résumé (en plus de cent pages) dans Algorithms for Computer Algebra, de Keith Geddes (en), Stephen Czapor et George Labahn. L'algorithme de Risch–Norman, plus rapide mais moins général, fut développé en 1976.

Sommaire

Description

L'algorithme de Risch a pour but d'intégrer des fonctions élémentaires, c'est-à-dire des fonctions obtenues par composition d'exponentielles, de logarithmes, de radicaux, des fonctions trigonométriques[1], et des quatre opérations arithmétiques (+ − × ÷). Laplace résolut ce problème pour le cas des fonctions rationnelles, en montrant que la primitive d'une telle fonction est somme d'une fraction rationnelle et de multiples de logarithmes de fractions rationnelles. L'algorithme suggéré par Laplace est généralement décrit dans les manuels de calcul intégral[2] ; en tant que programme informatique, il fut finalement implémenté dans les années 1960.

Entre 1833 et 1841, Liouville formula rigoureusement le problème que résout l'algorithme de Risch. Il montra (par des méthodes analytiques) que s'il existe une solution élémentaire g à l'équation g ′ = f, alors il y a des constantes αi et des fonctions élémentaires[3] ui et v telles que la solution soit de la forme

 g = v + \sum_{i<n} \alpha_i \,\ln (u_i)

(c'est le théorème de Liouville-Rosenlicht). Risch développa une méthode permettant de ne considérer qu'un ensemble fini de fonctions élémentaires ayant la forme donnée par Liouville.

L'intuition amenant à l'algorithme de Risch vient du comportement de la dérivée des exponentielles et des logarithmes. Ainsi, pour f eg, on a

 (f \cdot e^g)' = (f^\prime + f\cdot g^\prime)\cdot e^g, \,

donc si eg apparait dans une primitive, eg devrait déjà figurer dans la fonction initiale. De même, comme

 (f \cdot\ln^n g)' =  f^\prime \ln^n{g} + n f  \frac{g^\prime}{g} \ln^{n-1}{g} ,

si lnng apparait, seules les puissances inférieures du logarithme devraient être dans la fonction initiale.

Exemple

Axiom calculant la primitive de l'exemple

L'existence (ou non) d'une primitive élémentaire est extrêmement sensible aux détails exacts de la fonction à intégrer. Ainsi, la fonction suivante a une primitive élémentaire :

 f(x) = \frac{x}{\sqrt{x^4 + 10 x^2 - 96 x - 71}}.

Mais ce n'est plus le cas si 71 est remplacé par 72. La raison profonde en est que le groupe de Galois de

 x^4 + 10 x^2 - 96 x - 71 \,

est D(4), c'est-à-dire qu'il est engendré par les permutations (1 2 3 4) et (1 3), et contient huit éléments (comme celui de x4 − 2), alors que le groupe de Galois de

 x^4 + 10 x^2 - 96 x - 72 \,

est S(4), engendré par les permutations (1 2), (1 3), (1 4), et contient 24 éléments.

Implémentation

Transformer la procédure de décision de Risch en un algorithme pouvant être exécuté par un ordinateur, et ce de manière efficace, est une tâche complexe demandant l'utilisation d'heuristiques, et de nombreuses améliorations. De fait, en 2008, on ne connaissait aucun logiciel exécutant l'algorithme complet, quoique plusieurs systèmes de calcul formel utilisent une implémentation partielle. Le système Axiom est le seul annonçant avoir complètement implémenté la partie négative de l'algorithme, c'est-à-dire que si Axiom répond "non", la primitive demandée ne peut s'exprimer à l'aide des fonctions élémentaires, mais dans de nombreux cas, Axiom refuse de se prononcer.

Par exemple, de tous les programmes existants, seuls Axiom (voir l'illustration ci-dessus), Mathematica et WolframAlpha (qui peut être testé en ligne) peuvent trouver une primitive élémentaire pour la fonction de l'exemple précédent :

 f(x) = \frac{x}{\sqrt{x^4 + 10 x^2 - 96 x - 71}}

La solution renvoyée par Axiom est:


\begin{align}
F(x) = - \frac{1}{8}\ln &\,\Big( (x^6+15 x^4-80 x^3+27 x^2-528 x+781) \sqrt{ x^4+10 x^2-96 x-71} \Big.
\\
& - \Big .(x^8 + 20 x^6 - 128 x^5 + 54 x^4 - 1408 x^3 + 3124 x^2 + 10001) \Big) + C.
\end{align}

Beaucoup d'autres programmes ne peuvent trouver une primitive pour cette fonction qu'à l'aide d'intégrales elliptiques, des fonctions spéciales que l'algorithme de Risch ne sait pas traiter.

La fonction suivante[4] est un exemple plus complexe, que la plupart des logiciels[5] n'arrivent pas à intégrer en se limitant aux fonctions élémentaires :

f(x) = \frac{x^2+2x+1+ (3x+1)\sqrt{x+\ln x}}{x\,\sqrt{x+\ln x}(x+\sqrt{x+\ln x})}

Pourtant, la primitive de cette fonction a une forme assez simple :

F(x) = 2 (\sqrt{x+\ln x} + \ln(x+\sqrt{x+\ln x})) + C.

Décidabilité

L'algorithme de Risch appliqué à des fonctions élémentaires quelconques n'est en fait qu'un semi-algorithme, parce qu'il doit vérifier à certaines étapes que des coefficients d'expressions partielles obtenues sont ou non nuls. Même pour des expressions assez simples, on sait que cette question est indécidable : c'est le théorème de Richardson.

Il faut remarquer que cette difficulté se présente également pour de nombreux algorithmes apparemment sans problème, tel que l'algorithme de division des polynômes[6]. C'est pourquoi, en pratique, on utilise des heuristiques pour déterminer (avec un risque d'erreur) si ces simplifications ont lieu ou non.

Généralisations

On a pu étendre l'algorithme de Risch (tout comme le théorème de Liouville) à certaines classes de fonctions non élémentaires ; on consultera en particulier à ce sujet Bronstein 2005.

Notes

  1. Ces deux derniers cas sont en fait combinaisons d'exponentielles et de logarithmes complexes
  2. On le trouvera par exemple en ligne sur le site de les-mathematiques.net
  3. Les u et les v sont "plus élémentaires" que g ; voir l'article théorème de Liouville-Rosenlicht pour plus de détails
  4. Cet exemple vient de Bronstein 1998.
  5. Toutefois SymPy (en) peut l'intégrer.
  6. Pour une analyse détaillée de cette question, voir Mathematica 7 Documentation: PolynomialQuotient, Section: Possible Issues. Consulté le 15 février 2011

Références

Voir aussi


Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article Algorithme de Risch de Wikipédia en français (auteurs)

Игры ⚽ Нужно решить контрольную?

Regardez d'autres dictionnaires:

  • Projet:Mathématiques/Liste des articles de mathématiques — Cette page n est plus mise à jour depuis l arrêt de DumZiBoT. Pour demander sa remise en service, faire une requête sur WP:RBOT Cette page recense les articles relatifs aux mathématiques, qui sont liés aux portails de mathématiques, géométrie ou… …   Wikipédia en Français

  • Liste des algorithmes — Sommaire 1 Liste par catégories 1.1 Compression de données 1.2 Tri 1.2.1 Algorithmes en temps quadratique …   Wikipédia en Français

  • Axiom (logiciel) — Axiom Développeur Tim Daly et al. Dernière version 23 no …   Wikipédia en Français

  • Primitive — Pour les articles homonymes, voir Primitif.  Ne pas confondre avec la notion de fonction primitive en informatique. En mathématiques, une primitive (ou, rarement, antidérivée – de l anglais antiderivative) d une fonction f d une …   Wikipédia en Français

  • Système de calcul formel — Un système de calcul formel (computer algebra system ou CAS en anglais) est un logiciel qui facilite le calcul symbolique. La partie principale de ce système est la manipulation des expressions mathématiques sous leur forme symbolique. Sommaire 1 …   Wikipédia en Français

  • Théorie de Galois différentielle — La théorie de Galois différentielle est une branche des mathématiques qui a pour objet l étude des équations différentielles via des méthodes algébriques, plus particulièrement des méthodes issues de la théorie de Galois pour les équations… …   Wikipédia en Français

  • Théorème de Liouville (algèbre différentielle) — Pour les articles homonymes, voir Théorème de Liouville. En mathématiques, et plus précisément en analyse et en algèbre différentielle (en), le théorème de Liouville, formulé par Joseph Liouville dans une série de travaux concernant les… …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”