Algorithme de Rémy

Un article de Wikipédia, l'encyclopédie libre.
Ceci est une version archivée de cette page, en date du 25 avril 2019 à 18:39 et modifiée en dernier par PIerre.Lescanne (discuter | contributions). Elle peut contenir des erreurs, des inexactitudes ou des contenus vandalisés non présents dans la version actuelle.

L'algorithme de Rémy est un générateur d'arbres binaires, dont la principale application est un algorithme efficace de génération aléatoire d'arbres binaires.

Histoire

L'algorithme de Rémy est dû à Jean-Luc Rémy, chercheur au Centre de recherche en informatique de Nancy. Il a été créé en 1978 sans être publié immédiatement[1] et a fait partie du folklore de l'algorithmique et de la combinatoire énumérative[2] jusqu'à sa parution dans une revue francophone en 1985[3].

Description de l'algorithme

Les arbres binaires sont dénombrés par les nombres de Catalan donnés par les formules de récurrence :

.

Mais ces formules ne permettent pas de dériver un algorithme efficace de génération aléatoire.

L'idée de Rémy consiste à non plus compter les arbres binaires à nœuds, mais les arbres binaires décorés à nœuds, à savoir les arbres dont les feuilles ont été décorées par les nombres de à dans un ordonnancement quelconque. Il y a manières de décorer un arbre binaire, par conséquent, le nombre d'arbres binaires à nœuds internes est

Comme le note Knuth, Olinde Rodrigues avait déjà démontré cette formule, en 1838, dans un article du Journal de Liouville[4]. On note au passage que cela correspond à la récurrence linéaire sur les nombres de Catalan :

.

Rémy a remarqué qu'il y a moyens de construire un arbre décoré de taille à partir d'un arbre décoré de taille . On choisit un nœud interne ou externe (une feuille) dans cet arbre, appelons le . Comme il y a nœuds internes et feuilles, il y a choix possibles de . On insère alors un nouveau nœud interne et une nouvelle feuille décorée par , dont elle est la fille droite ou la fille gauche, tandis que en est alors le fils gauche ou le fils droit, comme cela est illustré dans les dessins ci-dessous.

La suite d'arbres ci-dessus illustre des insertions de nœuds conduisant à la construction d'un arbre binaire de taille .

Une suite d'arbres décorés illustrant l'algorithme de Rémy
Une suite d'arbres décorés illustrant l'algorithme de Rémy

On voit que ce processus est unique ; en effet, l'insertion peut être inversée par la coupe de la feuille de plus grand numéro. En conséquence, la construction de Rémy produit aléatoirement des arbres décorés de façon uniforme. Il suffit d'oublier les feuilles pour obtenir une génération aléatoire des arbres ordinaires (donc non décorés).

Implémentation efficace

Pour engendrer aléatoirement un arbre de taille , on peut écrire un algorithme efficace qui utilise un tableau de taille et qui fait tirages aléatoires dans des intervalles d'entiers, de taille respectivement, jusqu'à , d'où une complexité linéaire de l'algorithme en nombre de tirage uniforme dans un intervalle discret. Il est possible d'améliorer cet algorithme et d'atteindre un algorithme optimal en nombre de bits aléatoires utilisés[5].

Extensions

L'algorithme de Rémy est à l'origine de plusieurs échantillonneurs aléatoires efficaces d'arbres non binaires comptés par des nombres qui sont solutions d'équations holonomes (en)[5], notamment d'échantillonneurs aléatoires pour les arbres unaires-binaires.

Références

  1. Jean-Luc Remy, « Un procédé itératif de dénombrement d'arbres binaires et son application à leur génération aléatoire », dans Actes des 3e journées de la RCP Complexité, , aussi Rapport CRIN n°80-P-053 (1980).
  2. Dominique Foata et Doron Zeilberger, « A Classic Proof of a Recurrence for a Very Classical Sequence », J. Comb. Theory, Ser. A, vol. 80(2),‎ , p. 380-384 (lire en ligne)
  3. Jean-Luc Remy, « Un procédé itératif de dénombrement d'arbres binaires et son application à leur génération aléatoire », ITA, vol. 19(2),‎ , p. 179-195 (lire en ligne)
  4. Olinde Rodrigues, « Sur le nombre de moyens d'effectuer un produit de n facteurs », Journal de mathématiques pures et appliquées, vol. 3,‎ , p. 549 (lire en ligne)
  5. a et b Axel Bacher, Olivier Bodini et Alice Jacquot, « Efficient random sampling of binary and unary-binary trees via holonomic equations », Theor. Comput. Sci., vol. 695,‎ , p. 42-53.

Bibliographie

  • Jean-Luc Remy, « Un procédé itératif de dénombrement d'arbres binaires et son application à leur génération aléatoire », ITA, vol. 19(2),‎ , p. 179-195 (lire en ligne)
  • Donald E. Knuth, The Art of Computer Programming, vol. 4.4 (Generating all Trees), Addison Wesley, p. 18

Voir aussi