En théorie des automates, un automate à piles emboîtées est un automate fini qui utilise comme mémoire auxiliaire une pile dont les éléments peuvent eux-mêmes être des piles[1].
Mais contrairement à un automate à pile usuel, un automate à piles emboîtées peut se déplacer en avant et en arrière sur la « pile », qui est donc plutôt structurée en liste ; de plus, l'automate peut insérer une nouvelle pile, opérer sur elle, la détruire, et continuer à travailler sur l'ancienne pile. Ce mode opératoire peut être emboîté récursivement à une profondeur arbitraire ; toutefois, l'automate manipule toujours la pile la plus interne.
Un automate à piles emboîtées est capable de reconnaître un langage indexé, et de fait les langages indexés sont exactement les langages reconnus par les automates à piles emboîtées non déterministes[2],[1],[3].
Les automates à piles emboîtées diffèrent des automates à piles embarquées qui sont moins puissants puisque pour ces derniers, la mémoire auxiliaire, toujours organisée récursivement, n'est accessible que par le haut de pile. Les automates à pile embarquée reconnaissent exactement les langages engendrés par les grammaires d'arbres adjoints[4].
Description informelle
Un automate à piles emboîtées lit ses données sur une bande d'entrée ; le mot d'entrée n'est pas modifiable, il est délimité par deux marqueurs, et dans le cas bidirectionnel, la tête de lecture peut se déplacer sur la bande d'entrée en avant et en arrière ; pour des automates emboîtés unidirectionnels, la tête de lecture du mot d'entrée ne peut pas revenir en arrière.
L'automate est composé d'ensembles
, et qui sont des ensembles finis respectivement d'états, de symboles d'entrée et de symboles de pile ;
de marqueurs, notés , , et ; ce sont des symboles additionnels, utilisés comme marqueurs de début ou de fin de mots de pile;
d'un ensemble de règles de transition qui permettent des déplacements de la tête de lecture sur la bande d'entrée, et de la tête de lecture et écriture sur la pile.
La mémoire auxiliaire, appelée pile (« stack ») est en fait une structure linéaire où la tête de pile peut se déplacer dans les deux sens. La pile est un codage d'une structure arborescente : ses éléments sont soit des symboles de l'alphabet de pile , soit des piles elles-mêmes, représentées linéairement à l'aide de marqueurs de début et fin de pile. Les sous-piles peuvent elles-mêmes contenir des piles. Une pile peut se présenter typiquement sous la forme linéaire suivante :
Si, pour plus de lisibilité, on remplace les marqueurs , par des parenthèses ouvrante et fermante et qu'on omet marqueur , on obtient l'écriture :
La pile contient les éléments de l’alphabet de pile, puis une sous-pile réduite à l'élément suivie d'une deuxième sous-pile composée de et enfin la lettre . La tête de lecture-écriture est positionnée en début de la sous-pile , ce qui est représenté par un soulignement.
Exemple
Voici une séquence d'opérations et leur effet sur la pile. À l'étape 2, une pile est créée à l'intérieur de la sous-pile ; cette sous-sous-pile est . Elle est ensuite progressivement vidée, puis détruite à l’étape 5. À l'étape 8, la tête d'écriture sur la pile se retrouve au niveau du début et une insertion simple ajoute les symboles .
n°
action
pile
1:
2:
création de sous-pile
3:
pop
4:
pop
5:
destruction de sous-pile
6:
descente
7:
montée
8:
montée
9:
push
La description formelle des règles de transition est complexe, puisqu'elle doit tenir compte des symboles de pile et de la structure arborescente de la pile.
Propriétés
On peut définir des automates bidirectionnels à piles emboîtées, et on peut montrer que cela n'augmente pas la puissance de calcul par rapport aux automates à pile bidirectionnels ordinaires[5].
Robert Gilman et Michael Shapiro ont utilisé des automates à piles emboîtées pour résoudre le problème du motdans certains groupes certain groups[6].
↑Barbara Parteea, Alice ter Meulen et Robert E. Wall, Mathematical Methods in Linguistics, Kluwer Academic Publishers, , 666 p. (ISBN978-90-277-2245-4, présentation en ligne).
↑Introduction to Automata Theory, Languages, and Computation, Addison-Wesley, , 418 p. (ISBN978-0-201-02988-8). Dans ce livre, à la page 390.
↑C. Beeri, « Two-Way Nested Stack Automata Are Equivalent to Two-Way Stack Automata », J. Comp. and System Sciences, vol. 10, , p. 317–339 (DOI10.1016/s0022-0000(75)80004-3, lire en ligne)
↑Robert Gilman, Michael Shapiro, « On Groups Whose Word Problem is Solved by a Nested Stack Automaton », - pages=16, (arXiv9812028v1.pdf, lire en ligne)
Chaque classe de langages est strictement contenue dans la classe immédiatement au-dessus d'elle. Chaque automate et chaque grammaire d'une classe ont un équivalent dans la classe immédiatement au-dessus.