Méthode de Brzozowski et McCluskeyEn informatique théorique, et notamment en théorie des automates, la méthode de Brzozowski et McCluskey, aussi appelée méthode d'élimination d'états (« state elimination method »), est une méthode permettant d'obtenir une expression rationnelle à partir d'un automate fini. L'algorithme porte le nom de ses inventeurs, J. A. Brzozowski et E. J. McCluskey, qui l'ont présenté en 1963. L'algorithme est exposé dans plusieurs manuels[1],[2] ou des cours[3]. La méthode est également appelée algorithme de Kleene. PrincipeL'algorithme utilise de façon intensive la représentation graphique de l'automate. L'automate lui-même est généralisé, en autorisant, comme étiquettes des transitions, non seulement des lettres, mais des expressions rationnelles. Partant d'un automate fini, on élimine progressivement les états. À la fin, l'automate n'a qu'une seule transition, de l'état initial à l'état final, étiqueté par une expression rationnelle dénotant le langage reconnu par l'automate. Automate généraliséUn automate généralisé est défini comme un automate fini non déterministe traditionnel, avec les particularités suivantes :
Un mot w est reconnu par l'automate généralisé s'il existe un chemin allant de α à ω tel que w appartient au langage dénoté par le produit des expressions régulières apparaissant comme étiquettes de ce chemin. Le langage reconnu est l'ensemble des mots reconnus. Deux automates sont équivalents s'ils reconnaissent le même langage. On peut facilement transformer un automate ordinaire A en un automate généralisé : il suffit d'ajouter les états α et ω et des ε-transitions de α vers les états initiaux de A, et des ε-transitions des états terminaux de A vers ω. AlgorithmeÉtant donné un automate généralisé, on calcule un automate généralisé ayant moins de transitions ou d'états, en appliquant les transformations ci-dessous sans modifier le langage reconnu. À la fin, il ne reste que les deux états α et ω et une transition de α et ω dont l'étiquette est une expression régulière dénotant le langages reconnu. Les transformations sont des réductions des transitions et des réductions des états.
ExempleConsidérons l'automate suivant (qui reconnaît l'ensemble des mots contenant un nombre impair de lettres a).
Après adjonction des états α et ω, on élimine progressivement l'état 2 puis l'état 1.
On obtient l'expression rationnelle qui caractérise le langage reconnu par l'automate de départ. Notes et référencesBibliographie
Articles connexes
|
Portal di Ensiklopedia Dunia