Grammatica regolare

Da Wikipedia, l'enciclopedia libera.
Vai alla navigazione Vai alla ricerca

Una grammatica regolare, in informatica, è una grammatica formale generativa. Detta anche lineare destra o lineare sinistra, secondo la gerarchia di Chomsky è una grammatica di tipo-3.

Lo stesso argomento in dettaglio: Grammatica formale.

Come le altre grammatiche formali, è una quadrupla , in cui

  1. sono i simboli non terminali
  2. sono i simboli terminali
  3. detto assioma è il simbolo non terminale di inizio.
  4. sono le regole di produzione, una relazione binaria di cardinalità finita su , che normalmente scriviamo come
    questa scrittura ci dice che a sinistra ci deve essere almeno un non terminale ed a destra qualsiasi cosa.

Le produzioni di una grammatica regolare sono del tipo:

  • nel caso di lineari sinistre (in inglese left regular grammar)
ossia a sinistra della regola di produzione c'è un non terminale e a destra un non terminale seguito da un terminale oppure un singolo terminale.
  • nel caso di lineari destre (in inglese right regular grammar)
ossia a sinistra della regola di produzione c'è un non terminale e a destra un terminale seguito da un non terminale oppure un singolo terminale.

Poniamo attenzione al fatto che non ci devono essere produzioni miste formate da lineari destre e sinistre contemporaneamente nella stessa grammatica, poiché in questo caso non siamo più in presenza di una grammatica regolare ma ad una grammatica libera dal contesto (non contestuale) come evidenziato in un esempio seguente.

Vengono chiamate regolari perché i linguaggi generati da queste grammatiche sono rappresentabili tramite espressioni regolari.
Il termine lineare deriva dal fatto che a destra delle produzioni possiamo trovare al massimo un non terminale; destra o sinistra indica dove il non terminale sarà rispetto al terminale.

I linguaggi generabili da grammatiche regolari (di tipo-3) sono detti linguaggi regolari e sono equivalenti ai linguaggi riconosciuti dagli automi a stati finiti ed ai linguaggi rappresentati da espressioni regolari.

Ogni grammatica regolare è anche una grammatica libera dal contesto visto che le grammatiche tipo-3 sono strettamente contenute in quelle tipo-2 secondo la gerarchia di Chomsky.

Alcuni libri di testo e articoli non ammettono regole di produzione vuote (εいぷしろん-produzioni), e assumono che la stringa vuota non sia presente nel linguaggio.
Ad ogni modo è dimostrato il teorema che garantisce che data una grammatica le cui regole di produzione P possono essere separate in due sottoinsiemi contenenti uno le produzioni vuote e l'altro le produzioni di tipo regolare, allora esiste una grammatica regolare formata dalla grammatica a cui sono state eliminate le produzioni vuote.
Più formalmente regolare senza εいぷしろん-produzioni tale che

Un esempio di grammatica lineare destra con assioma, formato dalle seguenti regole di produzione:

Questa grammatica descrive lo stesso linguaggio dell'espressione regolare .

Un altro esempio di grammatica lineare destra con assioma, formato dalle seguenti regole di produzione:

Questa grammatica descrive lo stesso linguaggio dell'espressione regolare .

Esempio di grammatica non regolare

[modifica | modifica wikitesto]

Una grammatica che genera il linguaggio può essere con assioma, formato dalle seguenti regole di produzione:

ma questa non è una grammatica regolare bensì una grammatica libera dal contesto; ha entrambe le produzioni, destre e sinistre, e quindi non è regolare.

  • Giorgio Ausiello, Fabrizio d'Amore, Giorgio Gambosi. Linguaggi, Modelli, Complessità. Franco Angeli Editore, 2003 ISBN 88-464-4470-1

Voci correlate

[modifica | modifica wikitesto]
Teoria degli automi: linguaggi formali e grammatiche formali
Gerarchia di Chomsky Grammatica formale Linguaggio Automa minimo
Tipo-0 (illimitato) Ricorsivamente enumerabile Macchina di Turing
(illimitato) Ricorsivo Decider
Tipo-1 Dipendente dal contesto Dipendente dal contesto Automa lineare
Tipo-2 Libera dal contesto Libero dal contesto Automa a pila ND
Tipo-3 Regolare Regolare A stati finiti
Ciascuna categoria di linguaggio o grammatica è un sottoinsieme proprio della categoria immediatamente sovrastante.