Comparaison asymptotique
En mathématiques, plus précisément en analyse, la comparaison asymptotique est une méthode consistant à étudier le comportement d'une fonction au voisinage d'un point (ou en l'infini), en regard du comportement d'une autre fonction réputée « simple » et « connue », souvent choisie sur une échelle de référence. Cette échelle comprend en général les fonctions constructibles par somme, produit, élévation à une puissance réelle, différentiation et intégration de monômes, d'exponentielles et de logarithmes[1]. Cette méthode peut être utilisée pour traiter de gros volumes de données ou pour étudier le comportement de systèmes complexes en physique et en informatique, en particulier en théorie de la complexité des algorithmes. Elle est également utilisée en théorie analytique des nombres pour évaluer finement l'erreur commise lors de la détermination de l'ordre moyen d'une fonction arithmétique, un exemple célèbre étant le théorème des nombres premiers.
Cet article présente quelques cas de comparaison asymptotique, et introduit les notations de Bachmann, Landau, Hardy, Hardy et Littlewood, et Vinogradov.
Exemples de comparaison
La relation de prépondérance
Exemple
Soit Modèle:Math et Modèle:Math les fonctions réelles définies par les formulesModèle:Retrait
Par une étude des deux fonctions, on sait que Modèle:Math prend des valeurs aussi grandes que l'on veut au voisinage de l'infini, tandis que Modèle:Math ne peut prendre des valeurs qu'entre 1 et 3. Le quotient Modèle:Math divisé par Modèle:Math au voisinage de l'infini ne cesse d'augmenter et n'est pas borné. Dans ce contexte, on peut dire que Modèle:Math est négligeable devant Modèle:Math, ou que Modèle:Math est prépondérante devant Modèle:Math, au voisinage de l'infini, on écrit (notation de Landau[2]) :
ou (notation de Hardy[1]Modèle:,[3], désuète[4])
Définition formelle lorsque la fonction g ne s'annule pas
Pour définir formellement cette propriété on considère le comportement du quotient .
Soit
Soient Modèle:Math et Modèle:Math deux fonctions de la variable réelle Modèle:Math. On suppose que Modèle:Math ne s'annule pas sur un voisinage de a. On dit que Modèle:Math est négligeable devant Modèle:Math, ou que Modèle:Math est prépondérante[5] devant Modèle:Math en Modèle:Math, et on note , lorsque
Si le contexte est clair, on ne précise pas le domaine d'étude et on note : , voire . Cependant, la notation est toujours associée à un lieu a et au voisinage de ce lieu : être négligeable est un concept local.
Dans cette notation de Landau (parfois aussi ), le symbole se lit petit o. La notation équivalente de Hardy est . On utilise aujourd'hui exclusivement la notation de Landau.
Propriétés
Par abus de langage, on effectue des Modèle:Citation sur les Modèle:Citation, c'est-à-dire sur les négligeables. En effet, on peut dire que :
- ;
- .
Exemples
- Pour toute fonction , telle que , on a :
Équivalence
Définition formelle
Soit .
Soient Modèle:Math et Modèle:Math deux fonctions de la variable réelle Modèle:Math. On suppose que Modèle:Math ne s'annule pas sur un voisinage de Modèle:Math. On dit que Modèle:Math est équivalente à Modèle:Math en Modèle:Math, ou que Modèle:Math équivaut à Modèle:Math en Modèle:Math, et on note
- , lorsque .
Exemple
Domination
La notation grand O de Landau dénote le caractère dominé d'une fonction par rapport à une autre.
Généralement, comme Paul Bachmann qui a introduit ce symbole en 1894, on utilise la lettre O majuscule ("Ordnung"). C'est beaucoup plus tard (1976), par analogie avec le symbole oméga majuscule Ω (voir plus bas), que Donald Knuth a proposé de rebaptiser le symbole O du nom de la lettre omicron majuscule[6], celle-ci étant rarement dessinée de manière clairement différente du O. Surtout ne pas employer le chiffre zéro.
Définition formelle
Soient Modèle:Math et Modèle:Math deux fonctions de la variable réelle Modèle:Math. On dit que Modèle:Math est dominée par Modèle:Math en Modèle:Math, ou que Modèle:Math domine Modèle:Math en Modèle:Math, et on note (notation de Bachmann, 1894, ou de Landau, 1909)
ou (notation de Hardy[1], 1910, désuète)
ou encore (notation de Vinogradov, années 1930)
lorsqu'il existe des constantes Modèle:Math et Modèle:Math telles que
Intuitivement, cela signifie que Modèle:Math ne croît pas plus vite que Modèle:Math.
De même, si Modèle:Math est un nombre réel, nous écrivons
s’il existe des constantes Modèle:Math et Modèle:Math telles que
Exemples
- En un point Modèle:Math, si Modèle:Math est négligeable devant Modèle:Math ou équivalente à Modèle:Math, alors elle est dominée par Modèle:Math.
- Une fonction Modèle:Math est bornée sur un voisinage de Modèle:Math si et seulement si .
Absence de prépondérance et oscillations
Notation Ω de Hardy et Littlewood (théorie des nombres)
En 1914, Hardy et Littlewood ont introduit le nouveau symbole Ω[7] défini ainsi :
- .
Les fonctions Modèle:Math et Modèle:Math sont supposées définies, et Modèle:Math positive, dans un voisinage de l'infini. Ainsi est la négation de .
En 1916, les mêmes auteurs introduisent les deux nouveaux symboles ΩModèle:Ind et ΩModèle:Ind[8], définis de la façon suivante :
- ;
- .
Comme avant, les fonctions Modèle:Math et Modèle:Math sont supposées définies, et Modèle:Math positive, dans un voisinage de l'infini. Ainsi, est la négation de , et la négation de .
Contrairement à ce qu'affirmera plus tard D.E. Knuth[6], Edmund Landau a également utilisé ces trois symboles en 1924[9].
Ces notations de Hardy et Littlewood sont des prototypes, qui après Landau semblent n'avoir jamais été utilisés tels quels : [[#Notations de Landau|ΩModèle:Ind est devenu ΩModèle:Ind, et ΩModèle:Ind est devenu ΩModèle:Ind]].
Ces trois symboles sont maintenant couramment utilisés en théorie analytique des nombres, de même que pour signifier que les conditions et sont toutes deux satisfaites.
Il est clair que dans chacune de ces définitions on peut remplacer Modèle:Math par Modèle:Math ou par un nombre réel.
Exemples simples
On a
et plus précisément,
On a
et plus précisément,
cependant,
Deux définitions incompatibles
Il est important de souligner le fait que l'écriture
possède en mathématiques deux définitions incompatibles, toutes les deux très répandues, l'une en théorie analytique des nombres, qu'on vient de présenter, l'autre en théorie de la complexité des algorithmes. Lorsque ces deux disciplines se rencontrent, cette situation est susceptible de créer une grande confusion.
La définition de Knuth
En 1976, Knuth publie un article[6] dont le but principal est de justifier son utilisation du même symbole Ω pour décrire une autre propriété que celle décrite par Hardy et Littlewood. Il tente de convaincre le lecteur que la définition de Hardy et Littlewood n'est quasiment jamais utilisée (ce qui, même en 1976, est faux depuis en tout cas 25 ans[10]). Il va jusqu'à prétendre que Landau ne l'a jamais utilisée (ce qui est également faux[9]). Il ressent impérativement le besoin d'une autre notion (Modèle:Citation étrangère), et a décidé que l'utilisation du symbole Ω doit être réservé pour la décrire. Il est fortement contrarié par l'ancienne définition (Modèle:Citation étrangère).
Il prend donc le risque de créer la confusion, et définit
- [11].
Utilisation des comparaisons
Développements limités
En mathématiques, il est souvent important de garder un œil sur le terme d'erreur d'une approximation. Cette notation est particulièrement utilisée dès que l'on a affaire à des développements limités et à des calculs d'équivalents. Par exemple, le développement de la fonction exponentielle à l'ordre 2 peut aussi s'écrire:
pour exprimer le fait que l'erreur, la différence , est négligeable devant quand tend vers 0.
Il faut préciser que le nombre d'opérandes dans ce genre d'écriture doit être borné par une constante qui ne dépend pas de la variable : par exemple l'assertion est évidemment fausse si les points de suspension cachent un nombre de termes qui n'est pas borné lorsque x varie.
Échelle de comparaison
Voici une liste de catégories de fonctions couramment utilisées en analyse. La variable (notée ici n) tend vers Modèle:Math et c est une constante réelle arbitraire. Lorsque c est une constante supérieure à 1, les fonctions apparaissent dans cette liste par ordre croissant de grandeur.
notation | grandeur au plus | |
O(1) | module majoré par une constante | |
O(log(n)) | logarithmique | |
O((log(n))Modèle:Exp) | (polylogarithmique si c est entier positif) | |
O(n) | linéaire | |
O(n log(n)) | parfois appelée « linéarithmique », ou « quasi-linéaire » | |
O(nModèle:2) | quadratique | |
O(nModèle:Exp) | (polynomiale si c est entier positif) | |
O(cModèle:Exp) | (exponentielle si c est positif, parfois « géométrique ») | |
O(n!) | factorielle |
O(nModèle:Exp) et O(cModèle:Exp) sont très différents. Le dernier autorise une croissance bien plus rapide, et ce pour n'importe quelle constante c > 1. Une fonction qui croît plus rapidement que n'importe quel polynôme est dite superpolynomiale. Une fonction qui croît plus lentement que toute exponentielle est dite sous-exponentielle. Il existe des fonctions à la fois superpolynomiales et sous-exponentielles, comme la fonction nlog(n).
Remarquons aussi que O(log n) est exactement identique à O(log(nModèle:Exp)), puisque ces deux logarithmes sont multiples l'un de l'autre par un facteur constant et que la notation grand O « ignore » les constantes multiplicatives. De manière analogue, les logarithmes dans des bases constantes différentes sont équivalents.
La liste précédente est utile à cause de la propriété suivante : si une fonction f est une somme de fonctions, et si une des fonctions de la somme croît plus vite que les autres, alors elle détermine l'ordre de croissance de f(n).
- ex.: si f(n) = 10 log(n) + 5 (log(n))Modèle:3 + 7 n + 3 nModèle:2 + 6 nModèle:3, alors f(n) = O(nModèle:3).
Fonction à plusieurs variables
Cette notation peut aussi être utilisée avec des fonctions de plusieurs variables :
L'écriture : | quand |
correspond à la proposition : |
Pour certains, cette notation abuse du symbole d'égalité, puisqu'elle semble violer l'axiome d'égalité : « des choses égales à la même chose sont égales entre elles » (autrement dit, avec cette notation, l'égalité n'est plus une relation d'équivalence). Mais on peut également considérer que dans l'écriture
la notation "=O" désigne un seul opérateur, dans l'écriture duquel le signe "=" n'a pas d'existence propre indépendante (et en particulier ne désigne pas une relation d'équivalence). Il n'y a dans ce cas plus d'abus de notation, mais évidemment toujours un risque de confusion. Il est également possible de définir O(g(x)) comme un ensemble de fonctions, dont les éléments sont toutes les fonctions qui ne grandissent pas plus vite que Modèle:Math, et d'utiliser les notations ensemblistes pour indiquer si une fonction donnée est un élément de l'ensemble ainsi défini. Les deux conventions sont couramment utilisées mais la première (et plus ancienne) est jusqu'au début du Modèle:S- la plus souvent rencontrée. Pour éviter ce problème on utilise (tout aussi couramment) la notation de Vinogradov (voir ci-dessous).
Un autre problème est qu'il faut clairement indiquer la variable par rapport à laquelle le comportement asymptotique est examiné. Une affirmation telle que n'a pas le même sens selon qu'elle est suivie de « quand » ou, par exemple, de « (pour tout fixé) quand ».
La famille de notations de Landau O, o, Ω, ω, Θ, ~
Notation | Nom | Description informelle | Lorsque , à partir d'un certain rang... | Définition rigoureuse |
---|---|---|---|---|
ou
|
Grand O (Grand Omicron[6]) |
La fonction |Modèle:Math | est bornée par la fonction |Modèle:Math| asymptotiquement, |
pour un k > 0 | |
ou
|
Grand Omega | Deux définitions :
En théorie des algorithmes : Modèle:Math est minorée par Modèle:Math (à un facteur près) En théorie des nombres : |
En théorie des algorithmes :
pour un k > 0 En théorie des nombres : pour un k > 0 |
En théorie des algorithmes:
En théorie des nombres :
|
de l'ordre de ; Grand Theta |
Modèle:Math est dominée et soumise à Modèle:Math asymptotiquement | pour un k1 > 0, et un k2 > 0 |
||
ou
|
Petit o | Modèle:Math est négligeable devant Modèle:Math asymptotiquement | , quel que soit > 0 (fixé). | |
Petit Omega | Modèle:Math domine Modèle:Math asymptotiquement | pour tout k > 0 | ||
équivalent à | Modèle:Math est approximativement égale à Modèle:Math asymptotiquement | , quel que soit > 0 (fixé). |
Après grand-O, les notations Θ et Ω sont les plus utilisées en informatique ; le petit-o est courant en mathématiques mais plus rare en informatique. Le ω est peu usité.
Une autre notation parfois utilisée en informatique est Õ (soft-O en anglais) qui signifie grand-o à un facteur poly-logarithmique près.
En théorie des nombres la notation f(x)g(x)[3] a la même signification que f(x) = Θ(g(x)) (qui n'est pas utilisée).
Notations de Landau, notations de Hardy, notation de Vinogradov
Notations de Landau
Les notations de Landau portent le nom du mathématicien allemand spécialisé en théorie des nombres Edmund Landau qui utilisa le symbole O[2], introduit primitivement par Paul Bachmann[12], et s'en inspira pour inventer le symbole o. Il n'utilisa le symbole Ω que dans un seul article en 1924[9], pour signifier ≠ o ; cette notation avait été introduite (avec la même signification) en 1914 par G. H. Hardy et J. E. Littlewood[7] ; depuis, Ω est couramment utilisé en théorie des nombres, mais exclusivement dans ce même sens, et jamais dans le premier sens indiqué dans le tableau ci-dessus. Dans le même article Landau utilise les symboles ΩModèle:Ind et ΩModèle:Ind, également dus à Hardy et Littlewood[8], (et depuis notés ΩModèle:Ind et ΩModèle:Ind) pour signifier , respectivement . Il utilise bien sûr également la notation ∼, mais jamais ω ou Θ.
Notations de Hardy
Les notations de Hardy et , introduites par G. H. Hardy dans son tract de 1910 Orders of Infinity[1], jouent le même rôle que celles de Landau pour la comparaison asymptotique des fonctions.
En notation de Landau, on peut les définir comme suit :
et
Les notations de Hardy sont désuètes. Hardy a rapidement abandonné ses notations. Hardy utilise les notations de Landau dans tous ses articles (soit près de 400 !) et dans ses livres[13] sauf dans son tract de 1910 et dans 3 articles (1910-1913). Notons que si Hardy a introduit dans son tract de 1910 quelques autres symboles pour la comparaison asymptotique des fonctions, il n'a par contre jamais défini ou utilisé la notation , ni , comme il a été parfois affirméModèle:Par qui.
Notation de Vinogradov
Le théoricien des nombres russe Ivan Matveyevich Vinogradov introduisit dans les années 1930[14] la notation qui porte son nom,
- .
- La notation ≪ de Vinogradov, en revanche, est couramment utilisée en théorie des nombres à la place de O ; parfois même les deux notations sont utilisées indifféremment dans le même article.
Notes et références
Modèle:Traduction/Référence Modèle:Références
Voir aussi
Articles connexes
Lien externe
Modèle:En Big-O Cheat Sheet, un site répertoriant une classification des complexités algorithmiques par domaine.
- ↑ 1,0 1,1 1,2 et 1,3 Modèle:En G. H. Hardy, « The "Infinitärcalcül" of Paul du Bois-Reymond », Cambridge Tracts in Mathematics 12, 1910, deuxième édition 1924. Lire en ligne Modèle:Pdf.
- ↑ 2,0 et 2,1 Modèle:De Edmund Landau, Handbuch der Lehre von der Verteilung der Primzahlen, Berlin 1909, p. 883.
- ↑ 3,0 et 3,1 Modèle:HardyWright, Modèle:4e éd., Modèle:P..
- ↑ Quoique toujours mentionnée dans la Modèle:4e du Hardy and Wright, p. 7, comme étant occasionnellement utilisée, elle n'est en fait jamais employée dans la suite de l'ouvrage, où les auteurs recourent systématiquement à la notation équivalente o. Hardy lui-même n'a plus jamais utilisé cette notation dans ses travaux publiés après 1913.
- ↑ E. Ramis, C. Deschamp et J. Odoux, Cours de mathématiques spéciales, tome 3, p. 148
- ↑ 6,0 6,1 6,2 et 6,3 Modèle:En Donald Knuth, « Modèle:Langue », SIGACT News, avril-juin 1976, p. 18-24 Modèle:Lire en ligne Modèle:Pdf.
- ↑ 7,0 et 7,1 Modèle:En G. H. Hardy et J. E. Littlewood, « Some problems of Diophantine approximation », Acta Mathematica, vol. 37, 1914, p. 225
- ↑ 8,0 et 8,1 Modèle:En G. H. Hardy et J. E. Littlewood, « Contribution to the theory of the Riemann zeta-function and the theory of the distribution of primes », Acta Mathematica, vol. 41, 1916.
- ↑ 9,0 9,1 et 9,2 Modèle:De E. Landau, « Über die Anzahl der Gitterpunkte in gewissen Bereichen. IV », Nachr. Gesell. Wiss. Gött. Math-phys. Kl., 1924, p. 137-150
- ↑ Modèle:En E. C. Titchmarsh, The Theory of the Riemann Zeta-Function, Oxford, Clarendon Press, 1951
- ↑ Il se justifie en écrivant : Modèle:Citation étrangère
- ↑ Modèle:Lang, tome 2, 1894, p. 402.
- ↑ Voir par exemple Modèle:HardyWright.
- ↑ Voir par exemple « Une nouvelle estimation pour G(n) dans le problème de Waring » (en russe), Doklady Akademii Nauk SSSR, vol. 5, n° 5-6, 1934, p. 249-253. Traduction en anglais dans : Selected works / Ivan Matveevič Vinogradov ; prepared by the Steklov Mathematical Institute of the Academy of Sciences of the USSR on the occasion of his 90th birthday, Springer-Verlag, 1985.