Théorème de Parikh
En informatique théorique, et notamment dans la théorie des langages algébriques, le théorème de Parikh est un théorème qui compare les fréquences relatives d'apparition des lettres dans un langage algébrique. Il dit que si on compte, dans un langage formel, uniquement le nombre d'apparitions des lettres dans un mot, on ne peut pas distinguer les langages algébriques des langages rationnels.
Ce théorème a été prouvé par Rohit Parikh en 1966[1],[2], et il figure dans bon nombre de manuels d'informatique théorique[3],[4],[5].
Définitions et énoncé
Soit un alphabet. Le vecteur de Parikh d'un mot est le vecteur de donné par[3] :
- ,
où dénote le nombre d'occurrences de la lettre dans le mot .
Un sous-ensemble de est dit linéaire s'il est de la forme
pour des vecteurs . C'est donc l'ensemble des combinaisons linéaires, à coefficients entiers naturels, d'un ensemble fini de vecteurs de , auxquels est ajouté le vecteur . Par exemple, pour , l'ensemble est un ensemble linéaire très simple.
Un sous-ensemble de est dit semi-linéaire s'il est une union finie de parties linéaires.
L'énoncé du théorème est le suivant :
Théorème — Pour tout langage algébrique , l'ensemble des vecteurs de Parikh des mots de est un ensemble semi-linéaire.
On peut montrer que réciproquement, tout ensemble semi-linéaire est l'ensemble des vecteurs de Parikh d'un langage rationnel.
Deux mots sont commutativement équivalents s'ils sont des anagrammes l'un de l'autre, donc s'ils ont même vecteur de Parikh. Deux langages sont dits commutativement équivalents s'ils ont même ensemble de vecteurs de Parikh. D'après la remarque précédente, tout langage algébrique est commutativement équivalent à un langage rationnel. C'est sous cette forme que l'on trouve aussi parfois une formulation du théorème de Parikh.
Développements
La réciproque du théorème de Parikh est fausse : ainsi, en dimension 3, l'ensemble linéaire des vecteurs dont les trois composantes sont égales est l'ensemble des vecteurs de Parikh d'un langage non algébrique, à savoir du langage . Mais il y a plus : il n'existe aucun langage algébrique contenu dans dont l'ensemble des vecteurs de Parikh est [6]. Un langage contenu dans un ensemble , où les sont des lettres ou plus généralement des mots, est appelé un langage borné. Ces langages ont des propriétés particulières que Seymour Ginsburg[7] a traité dans un chapitre de son livre. Il donne une étude détaillée et une caractérisation des ensembles semi-linéaires qui correspondent à des langages algébriques bornés : il montre que les images de Parikh des langages algébriques bornés sont des ensembles semi-linéaires particuliers qu'il appelle « stratifiés ».
D'un point de vue plus algébrique, les ensembles semi-linéaires sont exactement les parties rationnelles du monoïde libre commutatif[8].
Notes et références
- (en) Rohit Parikh, « On Context-Free Languages », Journal of the Association for Computing Machinery, vol. 13, no 4, (lire en ligne).
- Une publication sous forme d'un rapport interne du MIT avec pour titre « Language Generating Devices », dans le Quarterly Progress Report du Research Laboratory of Electronics, no 60, 1961 p. 199-212. C'est cette référence que cite Gisnburg dans son livre.
- Kozen 1997, Supplementary Lecture H : Parikh's Theorem.
- Harrison 1978, Section 6.9 : Semi-linear sets and Parikh's Theorem.
- Carton 2008, Section 2.2.5 Théorème de Parikh.
- La précision « contenu dans » est essentielle car le langage convient tout en étant rationnel !
- Ginsburg 1966, Chapter 5 : Bounded languages.
- Sakarovitch 2009, Section II.7 : Rationals in commutative monoids.
Bibliographie
- (en) Dexter Kozen, Automata and Computability, New York, Springer-Verlag, (ISBN 3-540-78105-6).
- (en) Seymour Ginsburg, The Mathematical Theory of Context-free Languages, New York, McGraw-Hill, .
- (en) Michael A. Harrison, Introduction to Formal Language Theory, Addison-Wesley, , 594 p. (ISBN 0-201-02955-3, OCLC 266962302).
- (en) Jacques Sakarovitch, Elements of Automata Theory, Cambridge, Cambridge University Press, , 758 p. (ISBN 978-0-521-84425-3).
- Olivier Carton, Langages formels, calculabilité et complexité, [détail de l’édition] (lire en ligne)