Lemme d'Ogden

Pour un article plus général, voir Lemme d'itération pour les langages algébriques.

En informatique théorique, le lemme d'Ogden est un résultat de théorie des langages analogue au lemme de l'étoile. On l'utilise principalement pour démontrer que certains langages ne sont pas algébriques. Il est nommé ainsi d'après William F. Ogden, un informaticien théoricien américain qui l’a publié en 1968[1].

Le lemme d'Ogden est une version plus élaborée du lemme d'itération pour les langages algébriques, aussi connu sous le nom de lemme de Bar-Hillel, Perles et Shamir.

Il existe des langages qui satisfont le lemme d'Ogden mais qui ne sont pas algébriques. Ce lemme donne une condition nécessaire pour les langages algébriques, mais pas une condition suffisante. Il est très utile, dans sa version grammaticale, pour prouver que certains langages sont inhéremment ambigus.

Énoncés

Lemme d'Ogden

Étant donné un mot w = a 1 a 2 a n {\displaystyle w=a_{1}a_{2}\cdots a_{n}} , où les a i {\displaystyle a_{i}} sont des lettres, on appelle position dans w {\displaystyle w} tout entier de l'ensemble { 1 , 2 , , n } {\displaystyle \{1,2,\ldots ,n\}} . Un choix de N {\displaystyle N} positions distinguées ou positions marquées dans w {\displaystyle w} (ceci est la terminologie traditionnelle) est simplement un sous-ensemble I { 1 , 2 , , n } {\displaystyle I\subset \{1,2,\ldots ,n\}} de positions contenant N {\displaystyle N} éléments. Avec ces définitions, le lemme s'énonce comme suit :

Lemme d'Ogden — Soit L {\displaystyle L} un langage algébrique. Il existe un entier N {\displaystyle N} tel que pour tout mot w {\displaystyle w} de L {\displaystyle L} de longueur | w | N {\displaystyle |w|\geq N} , et pour tout choix de N {\displaystyle N} positions distinguées dans w {\displaystyle w} , il existe une factorisation w = x u y v z {\displaystyle w=xuyvz} telle que :

  1. ( x {\displaystyle x} et u {\displaystyle u} et y {\displaystyle y} ) ou ( y {\displaystyle y} et v {\displaystyle v} et z {\displaystyle z} ) contiennent au moins une position distinguée ;
  2. u y v {\displaystyle uyv} contient au plus N {\displaystyle N} positions distinguées ;
  3. x u n y v n z L {\displaystyle xu^{n}yv^{n}z\in L} pour tout n 0 {\displaystyle n\geq 0} .

Le plus petit entier N {\displaystyle N} pour lequel l'énoncé est vrai est appelé la constante d'Ogden.

Variante grammaticale

Il existe une variante grammaticale du lemme d'Ogden : elle dit que la paire itérante ( x , u , y , v , z ) {\displaystyle (x,u,y,v,z)} peut être choisie grammaticale. Cette variante est bien utile dans certains cas, et notamment pour les langages inhéremment ambigus. Voici l'énoncé :

Lemme d'Ogden (variante grammaticale) — Soit G {\displaystyle G} une grammaire algébrique d'axiome S {\displaystyle S} . Il existe un entier N {\displaystyle N} tel que pour tout mot w {\displaystyle w} qui dérive de S {\displaystyle S} de longueur | w | N {\displaystyle |w|\geq N} , et pour tout choix de au moins N {\displaystyle N} positions distinguées dans w {\displaystyle w} , il existe une factorisation w = x u y v z {\displaystyle w=xuyvz} telle que :

  1. ( x {\displaystyle x} et u {\displaystyle u} et y {\displaystyle y} ) ou ( y {\displaystyle y} et v {\displaystyle v} et z {\displaystyle z} ) contiennent au moins une position distinguée ;
  2. u y v {\displaystyle uyv} contient au plus N {\displaystyle N} positions distinguées ;
  3. Il existe une variable X {\displaystyle X} telle que S x X z ,   X u X v ,   X y {\displaystyle S{\stackrel {*}{\to }}xXz,\ X{\stackrel {*}{\to }}uXv,\ X{\stackrel {*}{\to }}y} .

Dans cet énoncé, le mot w {\displaystyle w} peut contenir des variables de la grammaire : il appartient au « langage élargi » constitué par définition de tous les mots dérivant de S {\displaystyle S} , qu'ils contiennent ou non des variables.

Exemples d'application

Langages non algébriques

  • Le langage L = { a n b n c n n 0 } {\displaystyle L=\{a^{n}b^{n}c^{n}\mid n\geqslant 0\}} n'est pas algébrique. Pour le voir, on distingue dans le mot a N b N c N {\displaystyle a^{N}b^{N}c^{N}} les lettres égales à a {\displaystyle a} . En appliquant le lemme, on fait varier le nombre de lettres a {\displaystyle a} . Il faut distinguer encore le cas où le facteur v {\displaystyle v} est vide ou non, mais comme on itère ce facteur, il ne peut être formé que de lettres de même type, et on ne peut pas compenser l'accroissement de lettres b {\displaystyle b} et c {\displaystyle c} à la fois, d'où la contradiction.
  • Le langage L = { a m b n c m d n n , m 0 } {\displaystyle L=\{a^{m}b^{n}c^{m}d^{n}\mid n,m\geq 0\}} n’est pas algébrique. On applique cette fois la variante grammaticale du lemme au mot w = a N b N c N d N {\displaystyle w=a^{N}b^{N}c^{N}d^{N}} , où N {\displaystyle N} est la constante d'Ogden, et où les lettres distinguées sont les lettres b {\displaystyle b} . Il existe des dérivations
S a N b k X d ,   X b i X d i ,   X b k ¯ c N d ¯ {\displaystyle S{\stackrel {*}{\to }}a^{N}b^{k}Xd^{\ell },\ X{\stackrel {*}{\to }}b^{i}Xd^{i},\ X{\stackrel {*}{\to }}b^{\bar {k}}c^{N}d^{\bar {\ell }}}
avec N = k + i + k ¯ = + i + ¯ {\displaystyle N=k+i+{\bar {k}}=\ell +i+{\bar {\ell }}} . On applique le lemme une deuxième fois, au mot a N b k X d {\displaystyle a^{N}b^{k}Xd^{\ell }} , où cette fois-ci ce sont les lettres a {\displaystyle a} qui sont distinguées. On obtient une paire itérante contenant des lettres a {\displaystyle a} itérées, mais aucune lettre d {\displaystyle d} , contradiction.

Langages non algébriques vérifiant le lemme

Le lemme d'Odgen est une condition nécessaire mais pas suffisante pour les langages algébriques.

  • Le langage L = { a n b m n m } { a n b n n  non premier  } {\displaystyle L=\{a^{n}b^{m}\mid n\neq m\}\cup \{a^{n}b^{n}\mid n{\text{ non premier }}\}} n’est pas algébrique, car étant un langage borné sur un alphabet à deux lettres, son complément (par rapport à a b {\displaystyle a^{*}b^{*}} ) est { a n b n n  premier  } {\displaystyle \{a^{n}b^{n}\mid n{\text{ premier }}\}} qui n’est pas algébrique. Pourtant, le langage vérifie le lemme d'Ogden[2].
  • Le langage L = b a a a b { a b p p  premier  } {\displaystyle L=b^{*}\cup aaa^{*}b^{*}\cup \{ab^{p}\mid p{\text{ premier }}\}} n'est pas algébrique, mais le lemme d'Ogden ne permet pas de le prouver parce qu'il n'y a pas moyen d'éviter d'itérer la lettre a {\displaystyle a} initiale [3].

Un langage inhéremment ambigu

  • Le langage L = { a n b n c m n , m 0 } { a m b n c n n , m 0 } {\displaystyle L=\{a^{n}b^{n}c^{m}\mid n,m\geq 0\}\cup \{a^{m}b^{n}c^{n}\mid n,m\geq 0\}} est inhéremment ambigu. Un langage est inhéremment ambigu si toutes les grammaires qui l'engendrent sont ambiguës. On applique une première fois la variante du lemme au mot w = a N b N c N + N ! {\displaystyle w=a^{N}b^{N}c^{N+N!}} N {\displaystyle N} est la constante d'Ogden, et en distinguant les lettres b {\displaystyle b} . Il existe une dérivation S x X z x u X v z x u y v z {\displaystyle S{\stackrel {*}{\to }}xXz{\stackrel {*}{\to }}xuXvz{\stackrel {*}{\to }}xuyvz} , et les conditions impliquent que u = a i {\displaystyle u=a^{i}} et v = b i {\displaystyle v=b^{i}} pour un entier 0 i N {\displaystyle 0\leq i\leq N} . En itérant N ! / i {\displaystyle N!/i} fois la dérivation X u X v {\displaystyle X{\stackrel {*}{\to }}uXv} on obtient un arbre de dérivation pour le mot a N + N ! b N + N ! c N + N ! {\displaystyle a^{N+N!}b^{N+N!}c^{N+N!}} . Cet arbre contient un sous-arbre dont la frontière ne contient que des lettres a {\displaystyle a} et b {\displaystyle b} , dont au moins N ! N {\displaystyle N!-N} lettres b {\displaystyle b} . En appliquant le même procédé au mot w = a N + N ! b N c N {\displaystyle w=a^{N+N!}b^{N}c^{N}} , on obtient un autre arbre de dérivation pour le même mot a N + N ! b N + N ! c N + N ! {\displaystyle a^{N+N!}b^{N+N!}c^{N+N!}} . Cet arbre contient un sous-arbre dont la frontière ne contient que des lettres b {\displaystyle b} et c {\displaystyle c} , dont au moins N ! N {\displaystyle N!-N} lettres b {\displaystyle b} . Cet arbre est donc différent du premier arbre.

Démonstration de la version grammaticale

Soit G {\displaystyle G} une grammaire algébrique de variables V {\displaystyle V} et d'axiome S {\displaystyle S} . Soit w {\displaystyle w} un mot qui dérive de S {\displaystyle S} .

La démonstration se trouve simplifiée si on ne veut établir que la version langage du lemme d'itération. Dans ce cas on peut choisir une grammaire sous forme normale de Chomsky, et un arbre de dérivation est essentiellement un arbre binaire.

Un lemme combinatoire

Considérons un arbre dont certaines feuilles sont distinguées. On dit que :

  • un nœud est distingué lorsque le sous-arbre dont il est racine contient des feuilles distinguée ;
  • un nœud est spécial lorsqu'au moins deux de ses enfants sont distingués.

Le parent d'un nœud distingué est distingué, la racine est distinguée dès que l'une des feuilles est distinguée, un nœud spécial est lui-même distingué.

Un arbre est de degré m {\displaystyle m} si chaque nœud a au plus m {\displaystyle m} enfants.

Lemme — Soit t {\displaystyle t} un arbre de degré m {\displaystyle m} avec k {\displaystyle k} feuilles distinguées. Si chaque branche contient au plus r {\displaystyle r} nœuds spéciaux, alors k m r {\displaystyle k\leq m^{r}} .

Démonstration

Si r = 0 {\displaystyle r=0} , il n'y a pas de nœud spécial ; il n'y a qu'une seule feuille distinguée, car s'il y en avait deux, leur ancêtre commun serait spécial. Supposons donc r 1 {\displaystyle r\geq 1} , et soit x {\displaystyle x} un nœud spécial dont aucun descendant n’est spécial ; chacun des sous-arbres de x {\displaystyle x} contient au plus une feuille distinguée, et comme x {\displaystyle x} a au plus m {\displaystyle m} enfants, l'arbre de racine x {\displaystyle x} contient au plus m {\displaystyle m} feuilles distinguées. On remplace maintenant chaque sous-arbre de cette nature une simple feuille distinguée. Le nombre de nœuds spéciaux diminue de 1 sur chaque branche. L'arbre obtenu a, par récurrence, au plus m r 1 {\displaystyle m^{r-1}} feuilles distinguées. Comme chacune des nouvelles feuilles a remplacé un sous-arbre avec au plus m {\displaystyle m} feuilles, ceci prouve le résultat.

Démonstration

Découpage du mot w {\displaystyle w} . On reste dans le langage en itérant la partie en couleur car b 1 {\displaystyle b_{1}} et b 2 {\displaystyle b_{2}} sont des nœuds étiquetés par la même variable X {\displaystyle X} .

On utilise la contraposée du lemme précédent : si l'arbre a strictement plus de m r {\displaystyle m^{r}} feuilles distinguées, alors l'arbre a au moins une branche qui contient au moins 1 + r {\displaystyle 1+r} nœuds spéciaux.

Soit m {\displaystyle m} la longueur maximale des membres droits des règles. On pose r = 2 ( | V | + 1 ) {\displaystyle r=2(|V|+1)} et N = 1 + m r {\displaystyle N=1+m^{r}} . Considérons un arbre de dérivation pour le mot w {\displaystyle w} . Par définition, l'arbre est de degré m {\displaystyle m} et possède des feuilles distinguées qui sont les positions distinguées de w {\displaystyle w} . L'arbre possède une branche ayant au moins 1 + r {\displaystyle 1+r} nœuds spéciaux, notés s 0 , , s r {\displaystyle s_{0},\ldots ,s_{r}} . Chacun de ces nœuds a au moins un fils distingué qui n'est pas sur la branche ; le nœud est gauche si ce fils est à gauche de la branche, il est droit sinon. Comme 1 + r = 2 | V | + 3 {\displaystyle 1+r=2|V|+3} , il y a au moins | V | + 2 {\displaystyle |V|+2} sommets distingués soit tous gauches, soit tous droits. Comme ce nombre est supérieur au nombre de variables, deux sommets s i {\displaystyle s_{i}} et s j {\displaystyle s_{j}} (notés b 1 {\displaystyle b_{1}} et b 2 {\displaystyle b_{2}} sur la figure), avec i < j {\displaystyle i<j} , sont étiquetés avec la même variable X {\displaystyle X} . L'arbre donne alors les dérivations

S x X z {\displaystyle S{\stackrel {*}{\to }}xXz} , X u X v {\displaystyle X{\stackrel {*}{\to }}uXv} et X y {\displaystyle X{\stackrel {*}{\to }}y} .

Si les nœuds distingués sont gauche, les mots x , u , y {\displaystyle x,u,y} contiennent des positions distinguées, sinon c'est le cas des mots y , v , z {\displaystyle y,v,z} . Enfin, si le mot y {\displaystyle y} contient plus que N {\displaystyle N} positions distinguées, on recommence le découpage à partir de la racine s j {\displaystyle s_{j}} de son sous-arbre.

Annexes

Notes et références

  1. Ogden 1968.
  2. Luc Boasson et S. Horváth, « On languages satifsfying Ogdens lemma », RAIRO. Informatique théorique, t. 12, no 3,‎ , p. 201-202 (lire en ligne).
  3. Jean Berstel et Luc Boasson, « Context-Free Languages », dans G. Rozenberg, A. Salomaa (éditeurs), Handbook of Theoretical Computer Science, vol. B : Formal Models and Sematics, Elsevier et MIT Press, (ISBN 0-444-88074-7), p. 59-102 —Example 2.5, p. 73.

Bibliographie

  • William F. Ogden, « A Helpful Result for Proving Inherent Ambiguity », Mathematical Systems Theory, vol. 2, no 3,‎ , p. 191-194 (DOI 10.1007/BF01694004)
  • Olivier Carton, Langages formels, calculabilité et complexité, [détail de l’édition] (lire en ligne) Document utilisé pour la rédaction de l’article
  • (en) Marcus Kracht, « Too Many Languages Satisfy Ogden’s Lemma », University of Pennsylvania Working Papers in Linguistics, vol. 10,‎

Articles connexes

v · m
Codage
Modèles de calcul
Algorithmique
Syntaxe
Sémantique
Logique mathématique
Mathématiques discrètes


  • icône décorative Portail des langues
  • icône décorative Portail de l’informatique
  • icône décorative Portail de l'informatique théorique