Linguagens e Gramáticas Linguagens Formais Hierarquia de...

60
Linguagens e Gramáticas Linguagens Formais Hierarquia de Chomsky

Transcript of Linguagens e Gramáticas Linguagens Formais Hierarquia de...

Page 1: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens e Gramáticas

Linguagens Formais

Hierarquia de Chomsky

Page 2: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Já vimos que

Linguagem é um conjunto de cadeias de símbolos sobre um alfabeto/vocabulário, V. É um subconjunto específico de V*. Estas cadeias são denominadas sentenças da linguagem, e são formadas pela justaposição de elementos individuais, os símbolos da linguagem.

Page 3: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Pode-se representar uma linguagem:

(1) Por meio da descrição do conjunto finito ou infinito de cadeias (Formalismo Descritivo)

Ex: Linguagem dos números pares; L={ 0n 1n | n 1}

(2) por meio de um Autômato (Formalismo Reconhecedor – Autômato)

Ex: Máquina de Turing

(3) por meio de uma Gramática que a gere (Formalismo Gerativo)

Page 4: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

4

Linguagens

LR

LLC

LRE

LSC

LR = Linguagens Regulares

LLC = Linguagens Livres de Contexto

LSL =Linguagens Sensíveis ao Contexto

LRE = Linguagens Recursivamente Enumeráveis

Hierarquia de Chomsky

Page 5: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Tipos de Linguagens e Gramáticas

Linguagens Gramáticas

Rec. Enumerável

(LRE)

Estrutura de Frase ou ou Irrestrita ou do

Tipo 0 (GEF)

Sensível ao contexto

(LSC)

Sensível ao contexto ou do Tipo 1

(GSC)

Livre de contexto

(LLC)

Livre de contexto ou do Tipo 2

(GLC)

Regular

(LR)

Regular ou do Tipo 3

(GR)

Page 6: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• O tipo mais geral de gramática é conhecido como tipo 0 ou com Estrutura de Frase ou Irrestritas

-> V+; V*

• Não há restrições nas regras de produção, a menos de que a cadeia nula não pode ocorrer do lado esquerdo.

G1= ( {S,A,B,C,D,E}, {a}, P,S ) P = { 1. S-> ACaB 5. aD -> Da 2. Ca -> aaC 6. AD -> AC 3. CB -> DB 7. aE -> Ea 4. CB -> E 8. AE -> } L(G1)=? • Menor cadeia: aa S =>1ACaB =>2AaaCB =>4AaaE =>7AaEa =>7AEaa =>8 aa

6

Tipos de Gramáticas

Page 7: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• A e B servem como marcadores da esq e dir para as formas sentenciais.

• C é o marcador que se move através da cadeia de a´s entre A e B, dobrando seu número pela produção 2.

• Quando C alcança o marcador à direita B, ele se torna um D ou E pela produção 3 ou 4.

• Se um D é escolhido, então ele migra à esquerda pela produção 5 até que o marcador à esq, A, seja alcançado.

• Nesse ponto, D se torna C de novo pela produção 6 e o processo recomeça.

• Se um E é escolhido, o marcador à direita (B) é consumido.

• O E migra à esquerda pela produção 7 e consome o marcador à esq pela produção 8.

L(G1) = {a2n | n é um inteiro positivo} 7

Page 8: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

8

Classes Gramaticais Conforme as restrições impostas ao formato das produções de uma gramática, a classe de linguagens que tal gramática gera varia correspondentemente. A teoria mostra que há quatro classes de gramáticas capazes de gerar quatro classes correspondentes de linguagens, de acordo com a denominada Hierarquia de Chomsky:

Gramáticas com Estrutura de Frase ou Irrestritas ou Tipo 0 Gramáticas Sensíveis ao Contexto ou Tipo 1 Gramáticas Livres de Contexto ou Tipo 2

Gramáticas Regulares ou Tipo 3

Page 9: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens LRE

As linguagens geradas pelas Gramáticas com Estrutura de Frase ou do Tipo 0 são chamadas de Linguagens Recursivamente Enumeráveis (LRE) ou Linguagens do Tipo 0.

São as linguagens para as quais há uma Máquina de Turing que as reconhece.

Correspondem às funções computáveis. 9

Page 10: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

10

Gramáticas Sensíveis ao/Dependentes de

Contexto ou Tipo 1 Se às regras de substituição for imposta a restrição de que nenhuma substituição possa reduzir o comprimento da forma sentencial à qual a substituição é aplicada, cria-se uma classe de gramáticas ditas sensíveis ao contexto. As gramáticas que obedecem a estas restrições pertencem, na hierarquia de Chomsky, ao conjunto das Gramáticas Sensíveis ao Contexto (GSC) ou do Tipo 1.

Page 11: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

11

Para as GSC, as produções são todas da forma

-> , com || <= || (produções não decrescentes) onde , (Vn Vt)+ Alguns autores colocam as produções de uma GSC como: 1A2 -> 12 com 1,2, V*, <> e A Vn para motivar o nome “sensível ao contexto” desde que a produção 1A2 -> 12 permite que A seja trocado por no contexto de 1 e 2. G2 = ({A,B,C}, {a,b,c},P,A) P = { A -> abc A -> aBbc Bb -> bB Bc -> Cbcc bC -> Cb aC -> aaB aC -> aa }

L(G2) = anbncn, n 1

Page 12: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens Sensíveis ao

Contexto - LSC As linguagens geradas pelas Gramáticas Sensíveis ao Contexto ou do Tipo 1 são chamadas de Linguagens Sensíveis ao Contexto (LSC) ou Linguagens do Tipo 1.

Resultado 1:

Toda gramática do tipo 1 é também do tipo 0.

Corolário 1:

Toda LSC é também uma LEF (mas nem toda LEF é LSC).

12

Page 13: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

13

Gramáticas Livres de Contexto ou Tipo 2 As Gramáticas Livres de Contexto (GLC) ou do Tipo 2 são aquelas cujas regras de produção são da forma: A -> onde A Vn, V+

Ou seja, quando do lado esquerdo da regra há apenas um símbolo não-terminal A gramática G3 é uma GLC. G3 = ({S,A,B}, {a,b}, P,S) P = {S -> aB | bA A -> a | aS | bAA B -> b | bS | aBB } L(G3) = ?

Page 14: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Menores cadeias: ab e ba S => aB => ab S => bA => ba S => aB => abS => abbA => abba => abaB => abab => aaBB => aabb S => bA => baS => baaB => baab => babA => baba => bbAA => bbaa L(G3) = {w {a,b}+ | nro(a) = nro(b)} Todas as combinações de cadeias em V+ com nro(a) = nro(b)

14

Page 15: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

15

As linguagens geradas pelas Gramáticas Livres de Contexto ou do Tipo 2 são chamadas de Linguagens Livres de Contexto (LLC) ou Linguagens do Tipo 2.

Resultado 2:

Toda gramática do tipo 2 é também do tipo 1.

Corolário 2:

Toda LLC é também uma LSC (mas nem toda LSC é uma LLC). Corolário 2.1:

Toda LLC é também uma LEF (mas nem toda LEF é uma LLC)

Linguagens Livres de Contexto (LLC)

Page 16: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

BNF

Outra maneira de se representar as Gramáticas Livres de Contexto é através da Forma Normal de Backus.

Neste caso, -> é substituído por ::= e os não terminais são

ladeados por < > No caso de repetições de lado esquerdo:

<A> ::= a1 <A >::= a2 : <A> ::= an escreve-se: <A> ::= a1| a2| ...| an

Os símbolos <,> , ::=, | formam a metalinguagem, ou seja, são

símbolos que não fazem parte da linguagem mas ajudam a descrevê-la. 16

Page 17: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Exemplo: G4 = {Vn, Vt, P, S} onde: Vn = {<sentença, <sn>, <sv>, <artigo>, <substantivo>, <verbo>}

Vt = {o, a, peixe, comeu, isca} S = <sentença> P = {

1. <sentença> ::= <sn> <sv> 2. <sn> ::= <artigo> <substantivo> 3. <sv> ::= <verbo> <sn> 4. <artigo> ::= o|a 5. <verbo> :: = mordeu 6. <substantivo> ::= peixe|isca }

Exercícios: a) verifique se a cadeia “a isca mordeu o peixe” é uma

sentença de L(G4). b) Dê exemplos de sentenças de L(G4). 17

Page 18: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

18

Mais GLC: G5= ({S}, {a, +, *, (, )}, P, S) P = {

S -> S * S S -> S + S S -> (S) S -> a }

L(G5)= conjunto das expressões aritméticas envolvendo *, +, ( ) e a.

Um exemplo de cadeia formada por esta gramática é a * (a + a).

Page 19: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

19

Processo inverso: Dada uma L(G) definir a gramática G. L(G6) = {ambn | m ≥ 1, n ≥ 1 }

Page 20: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

20

L(G6) = {ambn | m≥1, n≥1 } ou a+b+

Resp.: G6=({S, A, B}, {a, b}, P, S) P = {S -> AB A -> aA | a B -> bB | b } Obs.: Caso geral: Se A -> A| então A=> *

Page 21: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

21

L(G7) = {anbn | n ≥ 1}

Page 22: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

L(G7) = {anbn | n ≥ 1} G =({S},{a,b},P,S) P = {S -> aSb | ab }

22

Page 23: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Em uma gramática é possível haver várias derivações equivalentes (usam as mesmas produções nos mesmos lugares MAS em ordem diferente).

• Para GLC temos uma representação gráfica que representa uma classe de equivalências chamada Árvore de Derivação.

• Uma árvore de derivação para uma GLC G = (Vn,Vt,P,S) é uma árvore rotulada ordenada em que cada nó é rotulado por um símbolo de Vn Vt .

• Se um nó interno é rotulado com A e seus descendentes diretos são rotulados com X1, X2, ..., Xn então

A -> X1X2...Xn é uma produção de P.

Árvores de Derivação Sintática

Page 24: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Uma árvore rotulada ordenada D é uma árvore de derivação para uma GLC G(A) = (Vn,Vt,P,A) se

(1) A raiz de D é rotulada com A

(2) Se D1, ...Dk são as subárvores de descendentes diretos da raiz e a raiz de Di

é rotulada com Xi, então A => X1,...Xk é uma produção em P. Di deve ser a árvore de derivação para G(Xi) = (Vn,Vt,P,Xi) se Xi é não-terminal, e

Di é um nó simples rotulado com Xi se Xi é terminal.

(3) Se D1 é a única subárvore da raiz D e a raiz de D1 é rotulada com então A

-> é uma produção de P.

Vértices internos são não-terminais e vértices folhas podem ser não-

terminais, terminais ou .

Quando fazemos a árvore de derivação de uma sentença, os vértices folhas

são sempre terminais ou .

Uma sentença está representada na árvore de derivação fazendo-se a leitura

das folhas (nós sem descendentes) da esquerda para direita.

Page 25: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Exemplos

• Árvore de derivação para a sentença aabbaa da

GLC G = ({S,A},{a,b},P,S)

P: S-> aAS | a

A -> SbA | ba | SS

S

a A S

S b A a

a b a

Page 26: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Seja Ga = {{E,T,F}, {+,*,(,),a},P,E)

P: E -> E + T | T

T -> T * F | F

F -> (E) | a

1) Seja a sentença a + a *a. Mostre a derivação mais à esquerda e a

mais à direita.

• Derivação mais à esquerda (derivar primeiro o não-terminal mais à

esquerda):esquerda:

E=>E+T=>T+T=>F+T=>a+T=>a+T*F=>a+F*F=>a+a*F=>a+a*a

• Derivação mais à direita (derivar primeiro o não-terminal mais à direita): :

E=>E+T=>E+T*F=>E+T*a=>E+F*a=>E+a*a =>T+a*a=>F+a*a=>a+a*a

Page 27: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

2) Agora, mostre a árvore de derivação para

a + a * a

E

E + T

T T * F

F F a

a a

Única Árvore de Derivação

Page 28: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Agora considere a gramática Gb:

1. E -> E + E |E * E|(E)|a

Não é difícil ver que L(Ga)=L(Gb). Faça a árvore de derivação de a+a*a para Gb:

Não é única!!

E

E

E E

E E

*

+

a a a

E

E

E

E +

*

a a

a E

Gramática Ambígua

E=>E*E=>E+E*E=>a+E*E=>a+a*E=>a+a*a Der.esq.

E=>E+E=>a+E=>a+E*E=>a+a*E=>a+a*a Der.esq.

Page 29: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

De fato:

• Ga indica que o operador * tem precedência sobre o operador +

• Por Gb, ambos operadores têm igual precedência.

• A linguagem de uma gramática ambígua é dita ambígua.

• A ambiguidade decorre do fato de que as árvores de derivação implicam interpretações distintas.

Page 30: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Ambiguidade e Derivações mais

à Esquerda

Teorema: Para cada gramática

G=(Vn, Vt, P, S) e cadeias w em Vt*, w

tem duas árvores de análise sintática

distintas (logo, G é ambígua) se e somente

se w tem duas derivações mais à esquerda a

partir de S.

Page 31: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Ambiguidade nas GLC

• Um requisito importante de uma LP é que ela

não seja ambígua.

• O mais famoso caso de ambiguidade é o else

pendente, presente na especificação de muitas

LP.

Page 32: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Seja a gramática:

C -> if b then C else C

C -> if b then C

C -> s

Ela é ambígua desde que a cadeia

If b then if b then s else s

Pode ser interpretada como

(i) If b then (if b then s else s)

Ou

(ii) If b then (if b then s) else s

A primeira é a preferida em LP pois utiliza a regra informal “case o else com o if mais próximo” que resolve a ambiguidade

S : outro comando qualquer

Page 33: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Para eliminar a ambiguidade da gramática anterior, podemos reescreve-la com 2 não-terminais C1 e C2:

C1 -> if b then C1 | if b then C2 else C1 | s

C2 -> if b then C2 else C2 | s

O fato de que somente C2 precede o else

garante que, entre o par then-else gerado por qq uma das produções, deve aparecer ou um s ou outro then-else. Assim, a interpretação (ii) nunca ocorre.

(ii) If b then (if b then s) else s

Obs.: se essa for a interpretação desejada, então, nas LPs, usamos begin-end.

s : outro comando qualquer

Page 34: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Como mostrar que uma

gramática é ambígua?

• Com árvores de derivação.

• Def1: Uma GLC (G) é ambígua se há pelo menos uma cadeia pertencente à L(G) com mais de uma árvore de derivação para representá-la.

• Def2: A existência de uma sentença com duas ou mais derivações mais à esq (ou mais à dir) caracteriza uma linguagem ambígua.

Page 35: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Para retirar a ambiguidade de gramáticas de operadores:

– introduzimos várias variáveis e estratificamos as regras, quando temos operadores com várias prioridades de resolução.

– Para resolver a ambiguidade vinda do uso de vários operadores idênticos, forçamos o uso da recursão para esquerda ou direita (associatividade).

Gramática de Operadores

Page 36: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Regras de Precedência, Prioridade e

Associatividade • Ajudam na decisão da interpretação correta de expressões

nas LP

• Def: Um operador é associativo à esquerda se os operandos são agrupados da esq para dir, e é associativo à direita se os operandos são agrupados da dir para esq.

E -> E + T | T

T -> T * F | F

F -> (E) | a

Ex.: a + a + a (1º.; 2º.)

• Está relacionada com a posição da recursão nas regras que permitem um operador ser aplicado mais de uma vez:

• E E + T E + T + T T + T + T ... a+a+a

+ e*: associativos à esquerda

Page 37: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Os níveis de prioridade indicam a quais

operadores é permitido agrupar seus

operandos primeiro (resolver primeiro).

not Prioridade

* / div mod and

+ - or

< > <> >= <= =

Page 38: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens Inerentemente ambíguas

É simples encontrar um exemplo de GLC ambígua. Na

gramática abaixo para a sentença “a” temos 2

árvores

S -> A | B

A -> a

B -> a

Mas não é tão simples exibir uma LLC inerentemente

ambígua

Def : Uma LLC é inerentemente ambígua se não há

uma gramática não-ambígua que a gere.

Page 39: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

L = {ai bj ck | i,j,k >= 1 e i = j OU j = k}

S -> abc | aRbI | YbWc

I -> Ic | c

R -> ab | aRb

Y -> Ya | a

W -> bc | bWc

O fato de ser inerentemente ambígua decorre de que toda gramática que gera L gera cadeias para i=j por um processo diferente do qual usa para gerar as cadeias para j=k.

É impossível não gerar algumas cadeias para as quais i=j=k por ambos os processos.

Page 40: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

• Exemplo: aabbcc

S S

a R b I Y b W c

a b I c Y a b c

c a

Page 41: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Propriedades de Gramáticas

Ambíguas Teo : Não existe um algoritmo tal que, dada uma GLC

qualquer, retorne a resposta sim, se ela for ambígua, ou não, se ela não for ambígua. (Logo, essa propriedade é indecidível)

MAS

em casos particulares, nós podemos reconhecer a ambiguidade e remove-la “à mão”

E podemos utilizar classes mais restritas de GLC que, por definição, não são ambíguas (ex. LL(K))

Page 42: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Exemplos de produções

ambíguas

1. A -> AA

2. A -> A A

3. A -> A | A

4. A -> A | AA

Page 43: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Quais Gramáticas são ambíguas? (1) S -> bA | aB

A -> a | aS | bAA

B -> b | bS | aBB

(2) A gramática usada para gerar expressões aritméticas na notação posfix na linguagem APL:

S -> SS + | SS - | SS * | x | y

ou na notação prefix:

S-> +SS | -SS | *SS | x | y

(3) A gramática para gerar parênteses aninhados:

S -> (S) | ( ) | SS

(4) A gramática que define os operadores lógicos and e or

E -> E or E | E and E | (E) | a

Page 44: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

44

Gramáticas Regulares ou Tipo 3 Aplicando-se mais uma restrição sobre a forma das produções, pode-se criar uma nova classe de gramáticas, as Gramáticas Regulares (GR). Nas GRs, as produções são restritas às formas seguintes: A -> aB ou A -> a (linear à direita) ou A -> Ba ou A -> a (linear à esquerda) onde A,B Vn e a Vt

Page 45: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

45

As linguagens geradas pelas Gramáticas Regulares ou do Tipo 3 são chamadas de Linguagens Regulares (LR) ou Linguagens do Tipo 3. São as linguagens mais simples.

Resultado 3:

Toda gramática do tipo 3 é também do tipo 2.

Corolário 3:

Toda LR é também uma LLC (mas nem toda LLC é LR).

Linguagens Regulares (LR)

Page 46: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

46

Exemplo 1: G8 = ({S}, {a, b}, P, S) P = { S -> aS S -> b }

Page 47: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

47

Exemplo 1: G8 = ({S}, {a, b}, P, S) P = { S -> aS S -> b } Resp.: L(G8) = {anb| n ≥0} ou a*b

Page 48: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

48

Exemplo 2: G9 = ({S, A}, {a, b, c}, P, S) P = { S -> aS | bA A -> c }

Page 49: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

49

Exemplo 2: G9 = ({S, A}, {a, b, c}, P, S) P = { S -> aS | bA A -> c } Resp.: L(G9) = {anbc | n ≥ 0} ou a*bc

Page 50: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

50

Exemplo 3: G10 = ( {<Dig>, <Int>}, {+, -, 0, ..., 9}, P, <Int>) P = {<Int> ::= +<Dig> | -<Dig> <Dig> ::= 0<Dig> | 1<Dig>|...| 9<Dig> | 0 | 1 | 2 |...|9 }

Page 51: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

51

Exemplo 3: G10 = ( {<Dig>, <Int>}, {+, -, 0, ..., 9}, P, <Int>) P = {<Int> ::= +<Dig> | -<Dig> <Dig> ::= 0<Dig> | 1<Dig>|...| 9<Dig> | 0 | 1 | 2 |...|9 } Resp.: L(G10) = conj. números inteiros com sinal ±[0..9]+

Page 52: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

52

Exemplo 4: G11 = ( {A,B,C}, {0,1}, P, A) P = { A -> 0B | 0 B -> 1C C -> 0B | 0 }

Page 53: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

53

Exemplo 4: G11 = ( {A,B,C}, {0,1}, P, A) P = { A -> 0B | 0 B -> 1C C -> 0B | 0 }

Resp.: L(G11) = {0(10)*}

Page 54: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens Regulares e

Expressões Regulares

• Expressões Regulares (ER) denotam

conjuntos.

• Os conjuntos representados por ER

coincidem com as Linguagens Regulares

(LR).

• Assim, toda LR pode ser representada por

uma ER.

Page 55: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

55

Conclusões

Hierarquia de Chomsky Em termos gerais, para n {0, 1, 2, 3} pode-se afirmar que uma linguagem de qualquer tipo pode ser classificada também como sendo de tipo menor, de acordo com a Hierarquia de Chomsky. Uma linguagem do tipo n é caracterizada pela existência de alguma gramática do tipo n que a descreva.

Page 56: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

56

Linguagens

LR

LLC

LRE

LSC

LR = Linguagens Regulares LLC = Linguagens Livres de Contexto LSL =Linguagens Sensíveis ao Contexto LEF = Linguagens Recursivamente Enumeráveis

Hierarquia de Chomsky

Page 57: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens, Gramáticas e

Reconhecedores

Linguagens/Gramáticas Reconhecedores

Rec. Enumerável/GEF Máquina de Turing

Sensível ao

contexto/GSC

Máquina de Turing com memória

limitada

Livre de contexto/GLC Autômato a pilha

Regular/GR Autômato finito

A partir de agora, vamos estudar as Linguagens (Problemas) mais simples: LR e LLC e seus reconhecedores.

Page 58: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Linguagens e Reconhecedores

Linguagem Gramática Reconhecedor Tempo para reconhecer w; |w|=n

Tipo 0: Linguagens Computáveis ou Recursivamente Enumeráveis

Gramáticas com Estrutura de Frase

Máquinas de Turing

NP-completo

Tipo 1: Sensíveis ao Contexto

Gramáticas Sensíveis ao Contexto

Máquinas de Turing com memória limitada

Exponencial: O(2n)

Tipo 2: Livres de Contexto

Gramáticas Livres de Contexto

Autômatos à Pilha Polinomial

Espaço: O(n);

Tempo: Geral: O(n3);

Não-ambíguas: O(n2);

Se P= A->aB ou A->Ba ou A->a: O(n)

Tipo 3: Conjuntos Regulares

Gramáticas Regulares

Autômatos Finitos Linear: O(n) e O(|E|) (no tamanho do AF)

Page 59: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

Classifique as gramáticas, dê a quádrupla e a L(G) e

diga se são finitas/infinitas

1) E -> E + E | E - E | E * E | E / E | (E) | F F -> 0 | 1 | ... | 9 2) A -> BC BC -> CB B -> b C -> a 3) A -> 0A | B B -> 1B |

59

Page 60: Linguagens e Gramáticas Linguagens Formais Hierarquia de ...wiki.icmc.usp.br/images/archive/a/a5/20111005214439!Aula...As linguagens geradas pelas Gramáticas Livres de Contexto ou

4) S -> 0A A -> 1S | 1 5) S -> 0A A -> 1B B -> 1S | 1 6) L(G) = {111(00)*} G = ? 7) L(G) = {anbnc* | n >= 1 e i >= 0} G = ? 8) L(G) = {a*bncn | n >= 1 e i>= 0} G = ? 9) Utilize o software JFLAP com os exemplos acima

60