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]Modèle:,[2], et il figure dans bon nombre de manuels d'informatique théorique[3]Modèle:,[4]Modèle:,[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 : Modèle:Théorème
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].
La simplicité de l'énoncé et la complexité de la démonstration ont suscité tout un ensemble de variantes de preuves, parmi lesquelles il y a par exemple :
- [2021] Modèle:Article
- [2021] Modèle:Article
- [2011] Modèle:Article
- [1977] Modèle:Article
- [2002] Modèle:Article
- [1973] Modèle:Article
Notes et références
Bibliographie
Article lié
- ↑ Modèle:Article.
- ↑ Une publication sous forme d'un rapport interne du MIT avec pour titre « Modèle:Langue », dans le Modèle:Langue du Modèle:Langue, Modèle:Numéro, 1961 Modèle:P.. C'est cette référence que cite Gisnburg dans son livre.
- ↑ 3,0 et 3,1 Modèle:Harvsp.
- ↑ Modèle:Harvsp.
- ↑ Modèle:Harvsp.
- ↑ La précision « contenu dans » est essentielle car le langage convient tout en étant rationnel !
- ↑ Modèle:Harvsp.
- ↑ Modèle:Harvsp.