En informatique, le théorème d'Akra-Bazzi, appelé aussi la méthode d'Akra-Bazzi, sert à déterminer le comportement asymptotique des solutions de suites définies par récurrence qui apparaissent dans l'analyse asymptotique des coûts d'algorithme, notamment de la classe des algorithmes diviser pour régner. Le théorème est publié en 1998 et constitue une généralisation du Master theorem, puisque ce dernier ne s'applique qu'aux algorithmes du type « diviser pour régner » dont les sous-problèmes sont essentiellement de même taille.
où est une fonction qui satisfait les conditions suivantes :
La fonction est définie pour un nombre suffisant de valeurs initiales pour admettre une solution unique ;
Les nombres et sont des constantes pour tous les indices , et et ;
Pour la dérivée de , on a , pour une constante ( est le symbole de la notation de Landau) ;
pour tout i ;
est une constante.
Alors admet l'estimation suivante de son comportement asymptotique ( le symbole de la notation de Landau) :
où est tel que .
Les fonctions représentent une petite perturbation de l’argument de T. Comme et comme est toujours compris entre 0 et 1, on peut utiliser pour ignorer les différences avec les parties fractionnaires de l’argument. Par exemple, les fonctions et ont, d'après le théorème d'Akra-Bazzi, le même comportement asymptotique[2].
Une variante de la condition sur la dérivée de est la condition de croissance polynomiale de qui s'énonce comme suit : il existe des constantes positives et telles que pour on ait
pour tout réel dans la réunion des intervalles , pour .
Exemples
Tri fusion
Pour le tri fusion le nombre T(n) de comparaisons qui est une bonne mesure de sa complexité en temps est donné par l'équation récursive :
,
avec comme cas initial . On peut appliquer le théorème d'Akra-Bazzi avec , , , , et , et on obtient le comportement asymptotique
.
Diviser pour régner avec des sous-problèmes inégaux
On considère définie par
pour
et pour . On prend de sorte que
.
La formule s'évalue alors comme suit :
Importance et autres exemples
Le théorème d'Akra-Bazzi couvre une très vaste classe d'équations récursives et généralise de manière substantielle les résultats connus précédemment pour déterminer le comportement asymptotique. Il est utilisé en informatique pour déterminer la complexité en temps d'algorithmes récursifs du type diviser pour régner. Les exemples suivants sont donnés dans les notes de Leighton[3] et repris dans un cours de Chowdhury[4]
Mohamad Akra et Louay Bazzi, « On the solution of linear recurrence equations », Computational Optimization and Applications, vol. 10, no 2, , p. 195-210 (MR99c:68115, présentation en ligne) — Springer montre les deux premières pages.