Jump to content

User:Parhamhoushmand/Parikh Automaton

From Wikipedia, the free encyclopedia
A Parikh automaton.

In theoretical computer science , and in particular in automata theory , a Parikh automaton is a non-deterministic finite automaton whose transitions include vectors of natural integers which make it possible to test whether the sum of the vectors of a calculation satisfies a semi-linear constraint . The interest of this family of automata is that it has other equivalent characterizations, in the form of a Turing machine and in a more algebraic form, called RCM .

Informal description

[edit]

A Parikh automaton is a finite automaton whose transitions are labeled by pairs, Oris a letter of the input alphabet andis a vector of, for an integer. A path is a sequence

of transitions which calculates the wordand the vector, where the sum is done component by component. The acceptance condition is given by a set of terminal states and a semi-linear set. A path is a successful calculation if, starting from the initial state, it reaches a final state and if its vector belongs to the given semi-linear set.

Parikh automata were introduced in 2003 in the study of second-order logic  . These automata accept the same formal languages ​​as Turing machines with reversal bounded counters  . This family in turn coincides with a class defined by Massazza under the name RCM  class .

Example

[edit]

The automaton of introduction  , with the constraint, accepts all wordsabout the alphabetwhich begins and ends with a, and such that. `

Parikh Automata

[edit]

Semi-linear set

[edit]

A subset of is linear if it is of the form

for vectors . It is therefore the set of linear combinations, with natural integer coefficients, of a finite set of vectors of

, to which is added the vector . For example, for , is a very simple linear set.

Un sous-ensemble de 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

[edit]

Un automate de Parikh de dimension est un tuple , où

  • est l'alphabet,
  • est l'ensemble d'états
  • est l'état initial
  • est l’ensemble des états terminaux
  • est l'ensemble des contraintes semi-linéaires
  • est la relation de transition.

Un chemin dans l'automate est une suite

où, pour , le triplet est dans . L'étiquette de ce chemin est le couple . Le chemin est réussi ou acceptant si , et si de plus le vecteur est dans . Dans ce cas, le mot est accepté ou reconnu par l'automate . Le langage reconnu par est noté .

Automates inambigus

[edit]
Un automate de Parikh faiblement inambigu pour les contraintes et

Un automate de Parikh est faiblement inambigu[1] si, pour tout mot, il existe au plus un chemin réussi[2]. L'automate de la figure ci-contre est faiblement inambigu. Il a pour ensemble semi-linéaire de contraintes l'ensemble . Si on oublie la partie semi-linéaire, l'automate sous-jacent, qui reconnait le langage , 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[1]. Il existe des langages inhéremment faiblement inambigus au sens que tout automate de Parikh les reconnaissants est faiblement ambigu[1].

Caractérisation par machines de Turing

[edit]

Une machine de Turing à compteurs est une machine de Turing qui possède, en plus de ses attributs usuels, un ensemble de compteurs[3]. La machine, dans l'état et en lisant une lettre 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 -bornée si elle peut changer de direction au plus fois, et si chaque compteur ne peut alterner l'incrémentation et la décrémentation au plus fois. Une machine de Turing, à compteurs et -bornée est inambigue si, de plus, chaque mot possède au plus un calcul acceptant.

TheoremLes automates de Parikh reconnaissent les mêmes langages que les machines de Turing à compteurs et à renversements bornés[4] · [5].

L'égalité de ces familles de langages n'est plus vraie dans le cas déterministe. En revanche, la version inambigue est valide :

TheoremLes automates de Parikh faiblement inambigus reconnaissent les mêmes langages que les machines de Turing à compteurs et à renversements bornés inambigus[1].

Langages RCM

[edit]

Paolo Massazza[6] a introduit en 1993 une famille de langages appelée RCM. 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 totalement ordonné avec . À tout ensemble semi-linéaire de dimension on associe le langage . Ce langage est l'ensemble des mots dont les nombres d'occurrences de chaque lettre satisfont les contraintes de . Si par exemple et l'alphabet est , le langage est l'ensemble de tous les mots sur ces 4 lettres qui ont autant d'occurrences de que de et autant de que de .

Par définition, un langage sur un alphabet appartient à la famille RCM s'il existe un langage rationnel sur , un ensemble semi-linéaire et un morphisme préservant la longueur qui est injectif sur tels que

.

Par exemple, le langage est dans la famille RCM parce qu'il s'écrit sous la forme , où est l'ensemble semi-linaire défini ci-dessus et identifie et respectivement et .

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

TheoremLes automates de Parikh faiblement inambigus reconnaissent exactement les langages de la famille RCM[1].

Notes et références

[edit]
  1. ^ a b c d e Bostan et al. 2020.
  2. ^ Il existe aussi une notion d'automate de Parikh inambigu, définie dans (Cadilhac, Finkel & McKenzie 2013) mais qui est strictement plus forte. La définition ci-dessus correspond à la notion usuelle.
  3. ^ Ibarra 1978.
  4. ^ Cadilhac, Finkel & McKenzie 2012
  5. ^ Cite error: The named reference K was invoked but never defined (see the help page).
  6. ^ Massazza 1993.

Bibliographie

[edit]
  • Alin Bostan; Arnaud Carayol; Florent Koechlin; Cyril Nicaud (2020). "Weakly-unambiguous Parikh automata and their link to holonomic series" (PDF). 47th International Colloquium on Automata, Languages, and Programming: 114:1-114:16. doi:10.4230/LIPIcs.ICALP.2020.114. B. Retrieved 28 mai 2020. {{cite journal}}: Check date values in: |access-date= (help)CS1 maint: unflagged free DOI (link).
  • Michaël Cadilhac; Alain Finkel; Pierre McKenzie (2012). "Affine Parikh automata". RAIRO Theor. Inf. and Applic. 46 (4): 511-545. doi:10.1051/ita/2012013..
  • Michaël Cadilhac; Alain Finkel; Pierre McKenzie (2013). "Unambiguous constrained automata". Int. J. Found. Comput. Sci. 24 (7): 1099-1116. doi:10.1142/S0129054113400339..
  • Giusi Castiglione; Paolo Massazza (2017). "On a class of languages with holonomic generating functions". Theoretical Computer Science. 658: 74–84. doi:10.1016/j.tcs.2016.07.022..
  • Thomas Colcombet, « Unambiguity in automata theory », dans Jeffrey Shallit et Alexander Okhotin, Descriptional Complexity of Formal Systems - 17th International Workshop, Springer, coll. « LectureNotes in Computer Science » (no 9118), 2015 (DOI 10.1007/978-3-319-19225-3_1), p. 3–18.
  • Felix Klaedtke et Harald Rueß, « Monadic second-order logics with cardinalities », dans Automata, Languages and Programming, 30th International Colloquium, Springer, coll. « LectureNotes in Computer Science » (no 2719), 2003 (DOI 10.1007/3-540-45061-0_54), p. 74–84.
  • Paolo Massazza (1993). "Holonomic functions and their relation to linearly constrained languages". RAIRO - Informatique Théorique et Applications. 27 (2): 149-161. doi:10.1051/ita/1993270201491..
  • Erlich, Enzo; Guha, Shibashis; Jecker, Ismaël; Lehtinen, Karoliina (2022-09-16). "History-deterministic Parikh Automata". arXiv. arXiv:2209.07745.

Articles liés

[edit]

[[Category:Automata (computation)]]