En informatique théorique, en théorie des langages, une grammaire régulière, rationnelle ou à états finis est une grammaire hors-contexte particulière qui décrit un langage régulier. Les grammaires régulières donnent donc une autre possibilité que les expressions rationnelles et les automates finis pour décrire un langage régulier.
Définition
Une grammaire régulière peut être « à gauche » ou « à droite ».
- Une grammaire régulière à gauche est un ensemble de règles de la forme :
![{\displaystyle X\rightarrow Ya}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1453b7b2dd65ce9851c5c0e3e8e159a888c7bac6)
![{\displaystyle X\rightarrow a}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0b6b501b570d6123d5252cf065f145aa4ac14079)
![{\displaystyle X\rightarrow \epsilon }](https://wikimedia.org/api/rest_v1/media/math/render/svg/11f0d0bc6e11305e0a1e97bb3648787c68da084d)
où
,
sont des symboles non-terminaux et
un symbole terminal.
- Une grammaire régulière à droite est un ensemble de règles de la forme :
![{\displaystyle X\rightarrow aY}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7e8cf968f7921434c0e7ab28e4322eeec0fc7766)
![{\displaystyle X\rightarrow a}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0b6b501b570d6123d5252cf065f145aa4ac14079)
![{\displaystyle X\rightarrow \epsilon }](https://wikimedia.org/api/rest_v1/media/math/render/svg/11f0d0bc6e11305e0a1e97bb3648787c68da084d)
où
,
sont des symboles non-terminaux et
un symbole terminal. De plus, comme pour toutes grammaires, on considère un non-terminal particulier appelé axiome et noté
.
Exemple
La grammaire suivante est une grammaire régulière à droite :
![{\displaystyle S\rightarrow dA\mid rB\mid mC\mid \epsilon }](https://wikimedia.org/api/rest_v1/media/math/render/svg/f1ec09b7165e3fd7754ced3e3c938975fc97c467)
![{\displaystyle A\rightarrow oS}](https://wikimedia.org/api/rest_v1/media/math/render/svg/c11c257277db0b0d07d9ae53f2772611d9362656)
![{\displaystyle B\rightarrow eS}](https://wikimedia.org/api/rest_v1/media/math/render/svg/d3a1754266a91af518d2e84554ae2c908f66a47d)
![{\displaystyle C\rightarrow iS}](https://wikimedia.org/api/rest_v1/media/math/render/svg/02e24fbd7b0bdd9c1957d01471ec76179005a76b)
Avec la grammaire précédente, on peut engendrer le mot
. En effet :
.
Équivalence entre automates finis et grammaires régulières
On peut transformer de manière effective une grammaire régulière à droite en automate fini déterministe et vice versa. Les non-terminaux correspondent aux états de l'automate.
Exemple
Considérons la grammaire ci-dessus. L'automate correspondant est le suivant :
La suite de dérivations
correspond à la lecture du mot
dans l'automate où on passe successivement dans les états : S, A, S, B, S, C, S.
Soit une grammaire régulière à droite
, alors l'automate
équivalent à G est défini tel que:
avec
l'ensemble des états et
un état puits terminal,
avec
l'ensemble des symboles terminaux
avec
l'état initial
est la fonction de transition telle que, à la lecture d'un terminal
à partir d'un état
vers un autre état
.
La lecture de
permet de construire
. Pour chaque
:
- Si
alors on a ![{\displaystyle \delta (X,a)=Y}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1d01f1ac6ab3a4d7d368c6b3f8192a03b4aa8784)
- Si
alors on a ![{\displaystyle \delta (X,a)=q_{t}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/5d2aba3b8934e34ce118cff84e03f886f984f283)
- Si
alors on a
,
L'ensemble des états terminaux.
Le même type de jeu de règles peut être établi pour une grammaire régulière à gauche.
Liens externes
Théorie des automates, des langages formels et des grammaires formelles |
|
Chaque classe de langages est strictement contenue dans la classe immédiatement au-dessus d'elle. Chaque automate et chaque grammaire d'une classe ont un équivalent dans la classe immédiatement au-dessus. |