Automate de Parikh

De testwiki
Aller à la navigation Aller à la recherche
Un automate de Parikh.

En informatique théorique, et notamment en théorie des automates, un automate de Parikh est un automate fini non déterministe dont les transitions comportent des vecteurs d’entiers naturels qui permettent de tester si la somme des vecteurs d'un calcul satisfait une contrainte semi-linéaire. L'intérêt de cette famille d'automates est qu'elle possède d'autres caractérisations équivalentes, sous forme de machine de Turing et sous une forme plus algébrique, dite RCM.

Description informelle

Un automate de Parikh est un automate fini dont les transitions sont étiquetées par des couples (a,v), où a est une lettre de l’alphabet d’entrée et v est un vecteur de d, pour un entier d. Un chemin est une suite

q0a1,v1q1a2,v2qn1an,vnqn

de transitions qui calcule le mot a1an et le vecteur v1++vn, où la somme est faite composante par composante. La condition d’acceptation est donnée par un ensemble d’états terminaux et un ensemble semi-linéaire. Un chemin est un calcul réussi si, partant de l’état initial, il atteint un état final et si son vecteur appartient à l’ensemble semi-linéaire donné.

Les automates de Parikh ont été introduits en 2003 dans l’étude de la logique du second ordre[1]. Ces automates acceptent les mêmes langages formels que les machines de Turing à compteurs à renversements bornées (en anglais « reversal bounded »)[2]. Cette famille coïncide à son tour avec une classe définie par Massazza sous le nom de classe RCM[3].

Exemple

L’automate de l'introduction[4], avec la contrainte {(n1,n2,n1+n2n1,n20}, accepte l’ensemble des mots w sur l’alphabet {a,b,c} qui commence et finissent par un a, et tels que |w|a+|w|b=|w|c. `

Automates de Parikh

Ensemble semi-linéaire

Modèle:Loupe Un sous-ensemble de d est linéaire s'il est de la forme

u0+u1++uk={u0+t1u1++tmumt1,,tm}

pour des vecteurs u0,,um. C'est donc l'ensemble des combinaisons linéaires, à coefficients entiers naturels, d'un ensemble fini de vecteurs de d, auxquels est ajouté le vecteur u0. Par exemple, pour d=3, l'ensemble (1,0,0)+(1,1,1)={(n+1,n,n)|n} est un ensemble linéaire très simple.

Un sous-ensemble de d est semi-linéaire s'il est une union finie de parties linéaires. Tout ensemble semi-linéaire possède une représentation inambigue, où les unions sont disjointes et où les écritures comme combinaisons linéaires sont uniques.

Définition des automates

Un automate de Parikh de dimension d1 est un tuple 𝒜=(Σ,Q,qI,F,C,Δ), où

  • Σ est l'alphabet,
  • Q est l'ensemble d'états
  • qIQ est l'état initial
  • FQ est l’ensemble des états terminaux
  • Cd est l'ensemble des contraintes semi-linéaires
  • ΔQ×(Σ×d)×Q est la relation de transition.

Un chemin dans l'automate est une suite

q0a1,v1q1a2,v2qn1an,vnqn

où, pour 1in, le triplet (qi1),(ai,viqi) est dans Δ. LModèle:'étiquette de ce chemin est le couple (a1an,v1++vn). Le chemin est réussi ou acceptant si q0=qI, qnF et si de plus le vecteur v1++vn est dans C. Dans ce cas, le mot w=a1an est accepté ou reconnu par l'automate 𝒜. Le langage reconnu par 𝒜 est noté L(𝒜).

Automates inambigus

Un automate de Parikh faiblement inambigu pour les contraintes n1=n2+n3 et n2<n3

Un automate de Parikh est faiblement inambigu[4] si, pour tout mot, il existe au plus un chemin réussi[5]. L'automate de la figure ci-contre est faiblement inambigu. Il a pour ensemble semi-linéaire de contraintes l'ensemble C={(n1,n2,n3)n1=n2+n3 et n2<n3}. Si on oublie la partie semi-linéaire, l'automate sous-jacent, qui reconnait le langage c*(a+b)+, est en revanche un automate fini ambigu.

La famille des langages reconnus par des automates de Parikh faiblement inambigus est fermée par intersection ; la fermeture par union ou par complémentation est une question encore ouverte[4]. Il existe des langages inhéremment faiblement inambigus au sens que tout automate de Parikh les reconnaissants est faiblement ambigu[4].

Caractérisation par machines de Turing

Une machine de Turing à k compteurs est une machine de Turing qui possède, en plus de ses attributs usuels, un ensemble de k compteurs[2]. La machine, dans l'état q et en lisant une lettre a sur sa bande d'entrée, peut examiner ses compteurs, et incrémenter ou décrémenter certains de ses compteurs. La machine ne connaît pas la valeur de ses compteurs mais sait tester s'ils sont nuls ou non. Une machine de Turing est à renversements bornés (en anglais « reversal bounded ») si sa tête de lecture ne peut changer de direction qu'un nombre borné de fois ; plus précisément, elle est (m,n)-bornée si elle peut changer de direction au plus m fois, et si chaque compteur ne peut alterner l'incrémentation et la décrémentation au plus n fois. Une machine de Turing, à k compteurs et (m,n)-bornée est inambigue si, de plus, chaque mot possède au plus un calcul acceptant.

Modèle:Théorème

L'égalité de ces familles de langages n'est plus vraie dans le cas déterministe[6]. En revanche, la version inambigue est valide : Modèle:Théorème

Langages RCM

Paolo Massazza[3] a introduit en 1993 une famille de langages appelée RCM[7]. La construction rappelle, mais de loin, la représentation des langages algébriques par langages de Dyck. Ces langages sont définis comme suit.

On se donne un alphabet A={a1,,ad} totalement ordonné avec a1<<ad. À tout ensemble semi-linéaire C de dimension d on associe le langage [C]={wA*(|w|a1,,|w|ad)C}. Ce langage est l'ensemble des mots dont les nombres d'occurrences de chaque lettre satisfont les contraintes de C. Si par exemple C0={(n,m,n,m)|n,m0} et l'alphabet est a<b<c<d, le langage [C0]est l'ensemble de tous les mots sur ces 4 lettres qui ont autant d'occurrences de a que de c et autant de b que de d.

Par définition, un langage L sur un alphabet Σ appartient à la famille RCM s'il existe un langage rationnel R sur A={a1,,ad}, un ensemble semi-linéaire Cd et un morphisme préservant la longueur μ:A*Σ* qui est injectif sur R[C] tels que

L=μ(R[C]).

Par exemple, le langage Labab={anbmanbm|n,m0} est dans la famille RCM parce qu'il s'écrit sous la forme Labab=μ(R[C0]), où C0 est l'ensemble semi-linaire défini ci-dessus et μ identifie a et c respectivement b et d.

Le lien entre les langages RCM est les automates de Parikh est le résultat suivant :

Modèle:Théorème

Notes et références

Modèle:Références

Bibliographie

Articles liés

Modèle:Portail

  1. Modèle:Harvsp.
  2. 2,0 et 2,1 Modèle:Harvsp.
  3. 3,0 et 3,1 Modèle:Harvsp.
  4. 4,0 4,1 4,2 et 4,3 Modèle:Harvsp.
  5. Il existe aussi une notion d'automate de Parikh inambigu, définie dans Modèle:Harv mais qui est strictement plus forte. La définition ci-dessus correspond à la notion usuelle.
  6. Erreur de référence : Balise <ref> incorrecte : aucun texte n’a été fourni pour les références nommées C
  7. Le nom vient de que ces langages sont définis à l'aide de langages réguliers, de contraintes semi-linéaires et de morphismes.