Indice
Linguaggio libero dal contesto
Un linguaggio libero dal contesto (o non contestuale, o context-free) è un linguaggio formale generato da una grammatica che sia, appunto, non contestuale, ovvero tale che le cui regole agiscono su simboli non terminali a prescindere dal contesto in cui essi appaiono.
L'insieme dei linguaggi liberi da contesto è equivalente all'insieme dei linguaggi che sono riconoscibili da un automa a pila non deterministico. La semplicità del tipo di automa necessario al loro riconoscimento e il fatto che lo stesso possa essere generato direttamente dalla definizione della grammatica, rendono tale classe di linguaggi di particolare interesse nell'informatica teorica ed in particolare nella teoria dei linguaggi di programmazione e della loro implementazione.
Esempi
[modifica | modifica wikitesto]Un archetipo di linguaggio libero dal contesto è , il linguaggio di tutte le stringhe di lunghezza pari, di cui la prima metà è composta da , e la seconda metà da . Il linguaggio è generato dalla grammatica , ed è accettato dall'automa pushdown dove è definito in questo modo:
I linguaggi liberi dal contesto hanno molte applicazioni nei linguaggi di programmazione; per esempio, il linguaggio che verifica che le parentesi siano accoppiate in modo corretto è generato dalla grammatica .
Inoltre, le espressioni aritmetiche sono generate da grammatiche libere dal contesto e non regolari.[1]
Proprietà
[modifica | modifica wikitesto]- La famiglia dei linguaggi liberi dal contesto è chiusa per la concatenazione e l'unione ma non per l'intersezione o la differenza. In ogni caso è chiusa per l'intersezione e la differenza con linguaggi lineari.[2]
- Data una grammatica G di tipo 2, è decidibile stabilire se essa genera un linguaggio vuoto ().[3]
- Data una grammatica G di tipo 2, è decidibile stabilire se essa genera un linguaggio infinito.[4]
Note
[modifica | modifica wikitesto]- ^ http://www.cs.odu.edu/~toida/nerzic/390teched/regular/reg-lang/non-regularity.html
- ^ Ausiello, 2003, pp. 136-138.
- ^ Ausiello, 2003, pp. 138.
- ^ Ausiello, 2003, pp. 139.
Bibliografia
[modifica | modifica wikitesto]- Giorgio Ausiello, Fabrizio D'Amore, Giorgio Gambosi, Linguaggi modelli complessità, Milano, Franco Angeli Editore, 2003, ISBN 88-464-4470-1.
Voci correlate
[modifica | modifica wikitesto]- Il pumping lemma fornisce delle condizioni necessarie (ma non sufficienti) perché i linguaggi liberi dal contesto siano regolari.
Altri progetti
[modifica | modifica wikitesto]- Wikiversità contiene una lezione su linguaggio libero dal contesto
Collegamenti esterni
[modifica | modifica wikitesto]- Context-free, in Dizionario delle scienze fisiche, Istituto dell'Enciclopedia Italiana, 1996.
- Linguaggio context-free, in Enciclopedia della Matematica, Istituto dell'Enciclopedia Italiana, 2013.