Automate de Büchi

Un article de Wikipédia, l'encyclopédie libre.
Automate de Büchi non déterministe reconnaissant les mots infinis contenant un nombre fini de , c'est-à-dire l'ensemble .

En informatique théorique, un automate de Büchi est un ω-automate ou automate fini opérant sur des mots infinis, avec une condition d'acceptation particulière : une trace (ou calcul ou chemin infini) est réussie si et seulement si elle passe un nombre infini de fois par au moins un état acceptant. Un mot infini est accepté s'il est l'étiquette d'un calcul réussi. Ce type d'automate est utilisé en vérification de modèles.

Ce type d'automate a été défini par le mathématicien Julius Richard Büchi[1].

Définition[modifier | modifier le code]

Un automate de Büchi sur un alphabet est un ω-automate , où :

  • est un ensemble fini d'états ;
  • est l'ensemble des transitions ;
  • est l'ensemble des états initiaux ;
  • est un ensemble d'états finals ou terminaux ou acceptants.

Souvent on suppose que l'ensemble des états initiaux est composé d'un seul élément[2]. Une transition est composée d'un état de départ , d'une étiquette et d'un état d'arrivée . Un calcul (on dit aussi un chemin ou une trace) est une suite infinie de transitions consécutives :

Son état de départ est , son étiquette est le mot infini . Le calcul est réussi et le mot est accepté ou reconnu s'il passe infiniment souvent par un état terminal.

Un automate est déterministe s'il vérifie les deux conditions suivantes :

  • il possède un seul état initial ;
  • pour tout état , et pour toute lettre , il existe au plus une transition partant de et portant l'étiquette .

Exemples[modifier | modifier le code]

Automate de Büchi reconnaissant les mots infinis contenant un nombre infini de .

L'automate de Büchi déterministe donné par , avec deux états : et . L'état est initial. L'ensemble des états acceptants est . La fonction de transition est montrée dans le dessin à gauche.

Le mot infini n'est pas accepté car la seule trace correspondante est et le seul état qui apparaît une infinité de fois est qui ne figure pas dans . Par contre, le mot est accepté car il possède la trace , et y apparaît une infinité de fois et est dans . Il reconnaît les mots infinis contenant un nombre infini de . En rencontrant la lettre , l'automate retourne dans l'état , alors qu'une lecture de la lettre met l'automate dans l'état . Plus généralement, l'automate accepte exactement les mots infinis sur deux lettres et qui ne contiennent qu'un nombre fini de lettres , c'est-à-dire l'ensemble .

Automate de Büchi reconnaissant les mots infinis où chaque occurrence de est précédé d'un nombre pair non nul de .

Un autre exemple est l'automate de Büchi à droite ; il reconnaît les mots infinis où chaque occurrence de est précédé d'un nombre pair non nul de . L'automate possède trois états : , et . Il est aussi déterministe. L'automate démarre dans l'état et lit un nombre pair non nul de . Si l'automate a lu un nombre impair de , il est dans l'état , sinon dans l'état . La transition de l'état à l'état permet de lire la lettre après un nombre pair non nul de . Une lecture de depuis ou échoue.

Déterminisme versus non-déterminisme[modifier | modifier le code]

Les automates de Büchi déterministes sont strictement moins puissants que les automates de Büchi non déterministes[3],[4]. Par exemple, alors qu'il existe un automate de Büchi non déterministe à deux états qui reconnaît les mots infinis sur deux lettres et qui ne contiennent qu'un nombre fini de lettres , c'est-à-dire l'ensemble , cet ensemble n'est pas reconnu par un automate de Büchi déterministe.

Supposons le contraire, c'est-à-dire qu'il existe un automate de Büchi déterministe qui reconnaît ce langage, et soit son ensemble d'états d'acceptation. L'automate accepte le mot infini , dont le calcul passe une première fois dans un état de après la lecture d'un certain nombre positif, disons , de lettres . L'automate accepte aussi le mot infini , donc le calcul passe une deuxième fois par un état de après disons lettres . L'automate accepte donc le mot . De proche en proche, on construit un mot contenant une infinité de lettres et qui est accepté par l’automate, contradiction.

Langages reconnus[modifier | modifier le code]

Les ensembles de mots infinis reconnus par les automates de Büchi sont les ensembles rationnels de mots infinis ou ω-langages rationnels, à savoir les ensembles de la forme


où les et sont des langages rationnels pour tout , les ne contenant pas le mot vide. Ces langages sont aussi appelés les ω-fermeture de Kleene des langages rationnels[5].

La formule pour l'expression du langage reconnu par un automate de Büchi s'obtient comme suit : étant donné une automate de Büchi, notons l’ensemble des mots finis reconnus avec comme état initial et comme état final, donc les mots qui sont étiquettes d’un chemin de à . Ces langages (de mots finis) sont rationnels. Un mot infini est accepté s’il existe un calcul qui passe une infinité de fois par un état final, donc aussi s’il existe un état final disons , par lequel il passe une infinité de fois. Ceci est équivalent à dire que

pour un état initial . En prenant la réunion sur tous les états initiaux et terminaux, on obtient la description indiquée[5]. Pour démontrer que réciproquement tous les ω-langages rationnels sont reconnus par des automates de Büchi, on utilise les opérations de fermeture de la section suivante[6].

La description effective des ω-langages rationnels reconnus montre que le problème du mot est décidable pour les automates de Büchi, puisqu’il suffit de tester si l’un au moins des langages rationnels n’est pas vide.

Propriétés de clôture[modifier | modifier le code]

Les langages reconnus par des automates de Büchi fermés pour un certain nombre d'opérations qui se reflètent dans des constructions sur les automates.

  • Union : Soient et reconnaissant respectivement les langages et . Un automate reconnaissant la réunion s'obtient en faisant la réunion des deux automates. On suppose les ensembles d'états de et disjoints ; alors l’automate reconnaît la réunion.
  • ω-fermeture : Pour tout langage rationnel ne contenant pas le mot vide, le ω-langage est reconnu par un automate de Büchi. Soit un automate fini reconnaissant . On peut supposer qu'il n'a qu'un seul état initial noté , et qu'il n'y a pas de transition entrant dans . On ajoute à l'automate les transitions pour chaque transition de avec . L'automate de Büchi ainsi construit, avec un seul état initial qui est aussi terminal, reconnaît .
  • Concaténation : Pour tout langage rationnel et tout ω-langage reconnu par un automate de Büchi, le produit est un ω-langage reconnu par un automate de Büchi. Soient en effet un automate fini reconnaissant , avec , et un automate de Büchi reconnaissant . On peut supposer les ensembles d'états des deux automates disjoints. On peut aussi supposer que ne contient pas le mot vide, sinon on remplace le produit par . On construit un automate de Büchi qui a pour états l'union des ensembles d'états, pour transitions l'union des ensembles de transitions, augmentées des transitions pour pour chaque transition de qui mène vers un état terminal de . Enfin, ses états initiaux sont ceux de et ses états terminaux ceux de . Formellement, avec .

Ces trois propriétés démontrent que tout ω-langage rationnel est reconnaissable par un automate de Büchi.

  • Intersection : Soient et reconnaissant respectivement les langages et . Un automate reconnaissant l'intersection est construit de la manière suivante : , où les transitions de copient celles de et pour les deux premières composantes, et changent la troisième composante de 0 en 1 quand un état de apparaît dans la première composante, de 1 en 2 quand ensuite un état de apparaît dans la deuxième composantes, et retourne en 0 immédiatement après. Dans un calcul, un 2 apparaît infiniment souvent en troisième composante si et seulement un état de et un état de apparaissent infiniment souvent en première et en deuxième composante. Donc, en choisissant pour états terminaux de on obtient un automate de Büchi au comportement désiré[7].

Les langages reconnus par des automates de Büchi sont fermés par complémentation. Büchi en a donné une démonstration en 1962[1]. Plus tard, d'autres constructions de l'automate reconnaissant les langages complémentaires ont été développées[8],[9],[10],[11].

Lien avec les autres modes de reconnaissance[modifier | modifier le code]

Les automates de Büchi sont équivalents aux automates de Muller, aux automates de Rabin, automates de Streett ou automates de parité. Cependant, ils différent par leur concision. Par exemple, les automates de Büchi sont exponentiellement plus concis que les automates de Rabin dans le sens suivant : il existe une famille de langages (Ln)n=2.. sur l'alphabet {0, 1, #}, reconnaissable par des automates de Büchi non-déterministes de taille O(n) mais tout automate de Rabin non-déterministe équivalent doit être de taille au moins n![12].

Les automates de Büchi non déterministes représentent exactement les propriétés de la logique monadique de second ordre à un successeur (S1S), dites aussi propriétés ω-régulières[13]. La logique S1S est strictement plus expressive que la logique temporelle linéaire.

Il existe une condition duale à l'acceptation des automates de Büchi : il s'agit des automates co-Büchi. La condition d'acceptation est alors : une trace (ou calcul ou chemin infini) est réussie si et seulement si tout état apparaissant un nombre fini de fois est un état acceptant[14].

Algorithmique[modifier | modifier le code]

Logique du temps linéaire et model checking[modifier | modifier le code]

On utilise les automates de Büchi en vérification de modèles (model checking) où des questions algorithmiques se posent. Par exemple, savoir si le langage d'un automate de Büchi non-déterministe est vide se décide en temps linéaire[15]. On peut traduire une formule de la logique temporelle linéaire (LTL) en un automate de Büchi, mais dont la taille est exponentielle en la taille de la formule LTL[16]. Cette transformation peut servir à :

  • décider le problème de satisfiabilité de LTL. Ce problème est PSPACE-complet, mais voici un algorithme en temps exponentiel : construire un automate de Büchi équivalent à la formule LTL puis tester si son langage est vide ;
  • Faire de la vérification de modèles (model checking). Pour cela, on construit l'automate de Büchi équivalent à la formule LTL et on fait le produit avec le système à vérifier. Le produit est un automate de Büchi et il faut tester si son langage est vide.
Transformation d'un automate de Büchi généralisé en un automate de Büchi classique.

La transformation d'une formule LTL en un automate de Büchi est généralement présenté avec un intermédiaire, appelé automate de Büchi généralisé, où la condition d'acceptation est plus générale. Un automate de Büchi généralisé est comme un automate de Büchi, sauf que l'ensemble d'états terminaux est remplacé par une famille finie . La condition d'acceptation devient : une trace (ou calcul ou chemin infini) est réussie si et seulement si pour tout i, elle passe un nombre infini de fois par au moins un état acceptant de . Dans la figure ci-contre, l'automate du haut est un automate de Büchi correspondant à des mots sur l'alphabet {, cr1, cr2}. L'exemple provient de la propriété "infiniment souvent dans la section critique 1, et infiniment souvent dans la section critique 2". La lettre correspond à une section non critique, cr1 correspond à la section critique 1 et cr2 à la section critique 2. La famille est {{q1}, {q2}}. Une exécution acceptante, doit passer infiniment souvent par q1 et infiniment souvent par q2. Cela correspond bien à la propriété .

On transforme d'abord la formule LTL en un automate de Büchi généralisé (l'idée est que les états de l'automate sont les sous-ensemble maximaux consistants de sous-formules de la formule LTL). Par exemple, la propriété s'écrit en LTL : (toujours dans le futur cr1 et toujours dans le futur cr2). L'automate généralisé est donné dans la figure ci-contre, automate du haut. On transforme alors cet automate en un automate de Büchi usuel : il est obtenu en faisant une copie de l'automate généralisé pour chaque sous-ensemble . Dans l'exemple, l'automate est recopié deux fois : la première copie correspond à {q1} et la deuxième à {q2}. Une fois q1 rencontré, on passe dans la seconde copie. Une fois q2' rencontré, on repasse dans la première copie. L'automate obtenu est un automate de Büchi classique est la condition d'acceptation est de passer une infinité de fois par q1 ou q2'. Par construction, cette condition est équivalente à passer une infinité de fois dans q1 et une infinité de fois dans q2 dans l'automate généralisé.

Il existe des algorithmes efficaces en pratique pour construire un automate de Büchi équivalent à partir d'une formule LTL[17].

Il existe des algorithmes pour l'« apprentissage » d'un automate de Büchi[18].

S1S et WS1S[modifier | modifier le code]

Büchi[1] a montré qu'il y a équivalence, pour tout langage de mots infinis L, entre :

  • L est définissable par une propriété S1S (logique monadique de second ordre à un successeur) ;
  • L est définissable par une propriété WS1S (logique monadique de second ordre à un successeur, dite "weak", c'est-à-dire que la quantification du second ordre porte sur les ensembles finis) ;
  • L est reconnaissable par un automate de Büchi.

Les équivalences sont effectives : on transforme une formule S1S en un automate de Büchi. Ainsi, la logique S1S (et WS1S) est décidable. La logique S1S est de complexité non élémentaire[19].

Notes[modifier | modifier le code]

  1. a b et c Julius R. Büchi, « On a decision method in restricted second order arithmetic », Proc. International Congress on Logic, Method, and Philosophy of Science (1960), Stanford University Press,‎ , p. 1-12.
  2. Par exemple : Farwer 2002.
  3. Christel Baier et Joost-Pieter Katoen, Principles of Model Checking (Representation and Mind Series), The MIT Press, , 975 p. (ISBN 978-0-262-02649-9 et 9780262026499, lire en ligne), p. 191
  4. Erich Grädel, Wolfgang Thomas et Thomas Wilke, Automata logics, and infinite games : a guide to current research, Springer-Verlag New York, Inc., , 385 p. (ISBN 978-3-540-00388-5, lire en ligne), p. 11, sous-section 1.4.1
  5. a et b Farwer 2002, p. 6.
  6. Thomas 1990, p. 138-139.
  7. Thomas 1990, p. 138.
  8. Robert McNaughton, « Testing and generating infinite sequences by a finite automaton », Information and Control, vol. 9,‎ , p. 521-530 (DOI 10.1016/s0019-9958(66)80013-x).
  9. A. P. Sistla, M. Y. Vardi et P. Wolper, « The complementation problem for Büchi automata with applications to temporal logic », Theoretical Computer Science, vol. 49,‎ , p. 217–237 (DOI 10.1016/0304-3975(87)90008-9).
  10. S. Safra, « On the complexity of ω-automata », Proc. 29th IEEE Symposium on Foundations of Computer Science, White Plains, New York,‎ , p. 319–327.
  11. O. Kupferman et M. Y. Vardi, « Weak alternating automata are not that weak », ACM Transactions on Computational Logic, vol. 2, no 2,‎ , p. 408–429.
  12. Erich Grädel, Wolfgang Thomas et Thomas Wilke, Automata logics, and infinite games : a guide to current research, Springer-Verlag New York, Inc., , 385 p. (ISBN 978-3-540-00388-5, lire en ligne), p. 18, Theorem 1.30.
  13. Thomas 1990, p. 144-146.
  14. (en) Guillaume Sadegh, Laboratoire de Recherche et Développement de l’Epita, Complementing Büchi Automata, t. 0903, révision 2073 (Technical Report), Le Kremlin-Bicêtre, (lire en ligne)
  15. Christel Baier et Joost-Pieter Katoen, Principles of Model Checking (Representation and Mind Series), The MIT Press, , 975 p. (ISBN 978-0-262-02649-9 et 9780262026499, lire en ligne), p. 185, Th. 4.42
  16. Christel Baier et Joost-Pieter Katoen, Principles of Model Checking (Representation and Mind Series), The MIT Press, , 975 p. (ISBN 978-0-262-02649-9 et 9780262026499, lire en ligne)
  17. (en) Paul Gastin et Denis Oddoux, « Fast LTL to Büchi Automata Translation », Computer Aided Verification, Springer, Berlin, Heidelberg, lecture Notes in Computer Science,‎ , p. 53–65 (ISBN 3540445854, DOI 10.1007/3-540-44585-4_6, lire en ligne, consulté le )
  18. Yong Li, Yu-Fang Chen, Lijun Zhang et Depeng Liu, « A novel learning algorithm for Büchi automata based on family of DFAs and classification trees », Information and Computation, vol. 281,‎ , article no 104678 (DOI 10.1016/j.ic.2020.104678).
  19. « Luke Ong - Automata, Logic and Games: Theory and Application 1. Büchi Automata and S1S »

Références[modifier | modifier le code]

  • Wolfgang Thomas, « Automata on infinite objects », dans : Jan Van Leeuwen (éditeur), Handbook of Theoretical Computer Science: Formal Models and Semantics, t. B, MIT Press, , 1287 p. (ISBN 0-262-72015-9), p. 133-192
  • Berndt Farwer, « ω-Automata », dans : Erich Grädel, Wolfgang Thomas et Thomas Wilke (éditeurs), Automata, logics, and infinite games : A guide to current research, Springer-Verlag, coll. « Lecture Notes in Computer Science » (no 2500),‎ , viii+385 (ISBN 978-3-540-00388-5), p. 3-22.
  • Samuel Eilenberg, Automata, Languages and Machines, Vol. A, Academic Press, coll. « Pure and Applied Mathematics » (no 58), , xvi+451 (ISBN 978-0-12-234001-7), « Chap. XIV. Infinite Behavior of Finite Automata », p. 379-393.