Compiladores Aula 4. Celso Olivete Júnior.
|
|
|
- Jonathan de Miranda Carmona
- 7 Há anos
- Visualizações:
Transcrição
1 Aula 4 Celso Olivete Júnior [email protected]
2 Na aula de hoje... Revisão: gramáticas Relações em uma gramática: Cabeça, Último, Primeiro (First) e Seguinte (Follow) Capítulo 4 (seção 4.4.2) do livro : Princípios, técnicas e ferramentas 2
3 Definições Alfabeto ou vocabulário: Conjunto finito não vazio de símbolos. Símbolo é um elemento qualquer de um alfabeto. Ex: {a,b} {0,1,2,3,4,5,6,7,8,9} Cadeia: Concatenação de símbolos de um alfabeto. Define-se como cadeia vazia ou nula uma cadeia que não contém nenhum símbolo. Ex: aab λ cadeia nula 3
4 Definições Comprimento de cadeia: Número de símbolos de uma cadeia. Ex: aab = =6 λ =0 4
5 Definições Linguagem é uma coleção de cadeias de símbolos, de comprimento finito. Estas cadeias são denominadas sentenças da linguagem, e são formadas pela justaposição de elementos individuais, que são os símbolos ou átomos da linguagem. 5
6 Definições Métodos de Representação de Linguagens 1) Enumeração (especificação) das cadeias de símbolos que formam as suas sentenças (somente linguagens finitas podem ser representadas por este método) 2) Através de um conjunto de leis de formação das cadeias (Gramática) 3) Através de regras de aceitação de cadeias (às regras de aceitação dá-se o nome de Reconhecedor - autômatos) 6
7 Gramáticas 2) Leis de Formação Através de um conjunto de leis de formação das cadeias (ao conjunto de leis de formação dá-se o nome de Gramática) dada uma cadeia de símbolos, só é possível afirmar que tal cadeia pertence à linguagem se for possível, aplicando-se as leis de formação que compõem a gramática da linguagem, derivar (sintetizar) a cadeia em questão. Ao processo de obtenção de uma sentença a partir da gramática dá-se o nome de derivação da sentença. 7
8 Gramáticas Gramáticas Formalmente as gramáticas, são caracterizadas como quádruplas ordenadas onde: G = ( Vn, Vt, P, S) Vn representa o vocabulário não terminal (variáveis) da gramática. Este vocabulário corresponde ao conjunto de todos os símbolos dos quais a gramática se vale para definir as leis de formação das sentenças da linguagem. 8
9 Gramáticas Gramáticas Formalmente as gramáticas, são caracterizadas como quádruplas ordenadas onde: G = ( Vn, Vt, P, S) Vt é o vocabulário terminal, contendo os símbolos que constituem as sentenças da linguagem. Dá-se o nome de terminais aos elementos de Vt. 9
10 Gramáticas Gramáticas Formalmente as gramáticas, são caracterizadas como quádruplas ordenadas onde: G = ( Vn, Vt, P, S) P são as regras de produção, que definem o conjunto de todas as leis de formação utilizadas pela gramática para definir a linguagem. Para tanto, cada construção parcial, representada por um não-terminal, é definida como um conjunto de regras de formação relativas à definição do não-terminal a ela referente. A cada uma destas regras de formação que compõem o conjunto P dá-se o nome de produção da gramática 10
11 Gramáticas Gramáticas Exemplo: P: S AB A a B bb b Símbolos que derivam Símbolos terminais G = ( Vn, Vt, P, S) G = ({S, A, B}, {a, b}, P, S) 1. Qual a linguagem produzida por esta gramática? 2. Faça a árvore de derivação para a cadeiaabbbbb Regras de produção Início da derivação 11
12 Gramáticas Gramáticas Exemplo: P: S AB A a B bb b Símbolos que derivam Símbolos terminais G = ( Vn, Vt, P, S) G = ({S, A, B}, {a, b}, P, S) Regras de produção Início da derivação 1. Qual a linguagem produzida por esta gramática? Linguagem que começa com um símbolo a seguido de n símbolos b s (n 1). Expressão regular que representa a linguagem abb* 2. Faça a árvore de derivação para a cadeiaabbbbb 12
13 Gramáticas Árvore de derivação a raiz tem como rótulo o símbolo inicial S da gramática. a cada nó rotulado por um não-terminal A corresponde uma regra de A. Se a regra for A X 1 X 2... X m, os filhos do nó são rotulados, da esquerda para a direita, por X 1, X 2,..., X m. (cada um dos X i pode ser um terminal ou um nãoterminal.) um nó rotulado por um terminal é sempre uma folha da árvore, e não tem filhos. 13
14 Gramáticas Árvore de derivação para a gramática e cadeia abbbbb G = ({S, A, B}, {a, b}, P, S) P:{ S AB A a B bb b } 14
15 Gramáticas 1. Duas gramáticas G1 e G2 são equivalentes se produzem a mesma linguagem L(G1) = L(G2) 2. Uma sentença é ambígua se existem duas ou mais sequências de derivação que a define. 3. Uma gramática é ambígua se possui alguma sentença ambígua. G: S AB A AA B a B Bcd A Verifique se x= aaacd é ambígua. É ambígua permite derivação mais à direita e mais à esquerda 15
16 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. a. Gramáticas com Estrutura de Frase ou Tipo 0 b. Gramáticas Sensíveis ao Contexto ou Tipo 1 c. Gramáticas Livres de Contexto ou Tipo 2 d. Gramáticas Regulares ou Tipo 3 16
17 Classes Gramaticais a. GramáticascomEstruturadeFraseouTipo0 São aquelas às quais nenhuma restrição é imposta. Exemplo de reconhecedor: Máquina de Turing com fita de entrada infinita Produções da forma α β Onde: α (Vn Vt) + G = ( Vn, Vt, P, S) β (Vn Vt) * Lado esquerdo da regra de produção pode conter N símbolos (terminais ou não terminais); Lado direito da regra de produção pode conter N símbolos (terminais ou não terminais ou vazio); 17
18 Classes Gramaticais a. GramáticascomEstruturadeFraseouTipo0 Exemplo de GEF: G = ({A, B, C}, {a, b}, P, A) P: A BC BC CB B b C a Qual a linguagem gerada? L(G) =? 18
19 Classes Gramaticais a. GramáticascomEstruturadeFraseouTipo0 Exemplo de GEF: G = ({A, B, C}, {a, b}, P, A) P: A BC BC CB B b C a Qual a linguagem gerada? L(G) = {ba, ab} 19
20 Classes Gramaticais b. Gramáticas Sensíveis ao Contexto ou Tipo 1 Restrição: nenhuma substituição pode reduzir o comprimento da forma sentencial à qual a substituição é aplicada. Produções da forma α β Onde: α (Vn Vt) + β (Vn Vt) + α β 20
21 Classes Gramaticais b. Gramáticas Sensíveis ao Contexto ou Tipo 1 Exemplo de GSC: G = ({S, B, C}, {a, b, c}, P, S) P : S asbc abc CB HB HB HC HC BC ab ab bb bb bc bc cc cc Qual a linguagem gerada? L(G) = {a n b n c n n 1} Faça a derivação (mais à esquerda ou mais à direita) α β Onde: α (Vn Vt) + β (Vn Vt) + α β 21
22 Classes Gramaticais c.gramáticas LivresdeContexto outipo2 As Gramáticas Livres de Contexto (GLC) ou do Tipo 2 são aquelas que no lado esquerdo da regra há apenas um símbolo não-terminal. 22
23 Classes Gramaticais c.gramáticas LivresdeContexto outipo2 Qual a linguagem gerada para: G = ({S,A,B},{a,b},P,S) P: S AB A aa a B bb b L(G)={a n b m n, m 1} 23
24 Classes Gramaticais d. 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), de grande importância no estudo dos compiladores por possuírem propriedades adequadas para a obtenção de reconhecedores simples. Nas GRs, as produções são restritas às formas seguintes: A ab ou A Ba A a A ε onde A,B Vn e a Vt no lado esquerdo da regra há apenas um símbolo nãoterminal 24
25 Classes Gramaticais d. Gramáticas Regulares ou Tipo 3 Exemplo GR em EBNF: G = ( {<Dig>, <Int>}, {+, -, 0,..., 9}, P, <Int>) P: <Int> ::= +<Dig> -<Dig> <Dig> ::= 0<Dig> 1<Dig>... 9<Dig> Qual linguagem gerada? L(G) = conj. números inteiros com sinal ±[0..9] 25
26 Na aula de hoje... Revisão: gramáticas Relações em uma gramática: Cabeça, Último, Primeiro (First) e Seguinte (Follow) Capítulo 4 (seção 4.4.2) do livro : Princípios, técnicas e ferramentas 26
27 Relações em uma Gramática A construção de analisadores sintáticos é facilitada através de algumas funções associadas a gramática: CABEÇA, ÚLTIMO, PRIMEIRO(First) e Seguinte(Follow). Ideia: permitem escolher qual produção aplicar com base no próximo símbolo lido. Trecho de código... if(a<1) then a:=12... Analisador léxico retornou o token if Partes das regras em EBNF <comando condicional 1> ::= if <expressão> then <comando> [else <comando>] <comando repetitivo 1> ::= while <expressão> do <comando> 27
28 Cabeça É uma das mais simples de identificar um de seus elementos é a cabeça do lado direito de uma regra Dada uma produção na forma α βγ Onde: α Vn β (Vn Vt) γ (Vn Vt) * Cabeça(α)=β P: S AB A aa a B bb b Exemplo Cabeça (S) =? Cabeça (A) =? Cabeça (B) =? 28
29 Cabeça É uma das mais simples de identificar um de seus elementos (terminal ou não-terminal) é a cabeça do lado direito de uma regra Dada uma produção na forma α βγ Onde: α Vn β (Vn Vt) γ (Vn Vt) * P: S AB A aa a B bb b Exemplo Cabeça (S) = {A} Cabeça (A) = {a} Cabeça (B) = {b} Cabeça(α)=β 29
30 Último Relaciona um dado não terminal, existente do lado esquerdo de uma certa regra, com o último elemento que aparece do lado direito desta regra Dada uma produção na forma α γβ Onde: α Vn P: S AB A aa a B bb b Exemplo β (Vn Vt) γ (Vn Vt) * Último (S) =? Último (A) =? Último (B) =? Último(α)=β 30
31 Último Relaciona um dado não terminal, existente do lado esquerdo de uma certa regra, com o último elemento (terminal ou nãoterminal) que aparece do lado direito desta regra Dada uma produção na forma α γβ Onde: α Vn β (Vn Vt) γ (Vn Vt) * Último(α)=β P: S AB A aa a B bb b Exemplo Último (S) = {B} Último (A) = {A,a} Último (B) = {B,b} 31
32 Primeiro (First) Relação próxima a relação cabeça; entretanto, deve conter somente terminais Primeiro(A) = x, onde A produz x como seu símbolo mais à esquerda com n derivações, sendo A Vn e x Vt* x pode ser a cadeia vazia P: S AB A aa a B bb b Exemplo Primeiro (S) = {a} Primeiro (A) = {a} Primeiro (B) = {b} 32
33 Primeiro (First) Para determinar PRIMEIRO(X): 1. Sexéum terminal, então PRIMEIRO(x) = {x} 2. Se X é não-terminal e X aα é uma produção, então se acrescenta a ao conjunto PRIMEIRO de x 3. SeXεéuma produção ε deve ser adicionado ao conjunto PRIMEIROde x 4. Se XY 1 Y 2...Y k é uma produção, então todo i tal que todos Y 1...Y i-1 são nãoterminais e PRIMEIRO(Y j ) contém ε, onde j=1,2...i-1. acrescente todo símbolo diferente de ε de PRIMEIRO(Y j ) a PRIMEIRO(X). Se ε PRIMEIRO(X), para todo i=1,2..k. então acrescente ε a PRIMEIRO(X). 33
34 Primeiro (First) Exemplo E TE E +TE ε T FT T *FT ε F (E) id Primeiro (E) = {?} Primeiro (E ) = {?} Primeiro (T) = {?} Primeiro (T ) = {?} Primeiro (F) = {?} 34
35 Primeiro (First) Exemplo E TE E +TE ε T FT T *FT ε F (E) id Primeiro (E) = Primeiro(T) = Primeiro(F) ={(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} F deriva em ε? R: Não, então primeiro(t) = primeiro(f) = {(, id} Se F derivasse em ε era preciso incluir o primeiro(t ) em primeiro(t) 35
36 Primeiro (First) Exemplo 2 E TE E +TE ε T FT H E T T *FT ε F (E) id Primeiro (H) = {?} Se fosse incluída esta regra na gramática como ficaria o primeiro(h)? 36
37 Primeiro (First) Exemplo 2 E TE E +TE ε T FT H E T T *FT ε F (E) id Primeiro (H) = Primeiro(E ) Primeiro(T) = {+, (, id } Regra 4 slide 33 E deriva em ε? R: Sim, então incluir o primeiro(t) em primeiro(h). Se primeiro(t) e primeiro(e ) contem ε então incluir ε em primeiro(h), caso contrário remover ε do primeiro(h) 37
38 Seguinte (Follow) Se A é um não-terminal, Seguinte(A) é o conjunto de terminais que podem figurar imediatamente à direita de A em alguma forma sentencial Seguinte(A)=x para a regra SαAβ e primeiro(β)=x Onde: A Vn x Vt * αe β (Vn Vt) * 38
39 Seguinte (Follow) Para determinar Seguinte(A): 1. Colocar $ em Seguinte(S) se S é o símbolo de partida - $ é o marcador de fim de entrada durante a análise sintática 2. Se existe uma produção A αbβ e β ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contem ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 39
40 Seguinte (Follow) Seguinte(A)=x para a regra SαAβ e primeiro(β)=x E TE E +TE ε T FT T *FT ε F (E) id Colocar Colocar $ em em Seguinte(S) Seguinte(S) se se S é o símbolo símbolo de de partida - é o marcador de fim de entrada partida 2. Se existe uma produção A αbβ diferente 2. Se existe uma produção A αbβ e β é diferente de então tudo que estiver em PRIMEIRO(β), de ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm (β ε), então tudo onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) que está em Seguinte(A) está em Seguinte(B) Primeiro (E) = Primeiro(T) = Primeiro(F) = {(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} Regra 2 e Regra 1 Seguinte(E) = {), $} Seguinte(E ) = Seguinte(E) = {), $} Seguinte(T) = Primeiro(E ) = {+} U Seguinte(E) U Seguinte(E ) = {+,), $} Seguinte(T ) = Seguinte(T)= {+,), $} Seguinte(F) = primeiro(t') = {*} U Seguinte(T) U Seguinte(T ) = {*,+,), $} 40
41 Seguinte (Follow) Seguinte(A)=x para a regra SαAβ e primeiro(β)=x E TE E +TE ε T FT T *FT ε F (E) id Colocar Colocar $ em em Seguinte(S) Seguinte(S) se se S é o símbolo símbolo de de partida - é o marcador de fim de entrada partida 2. Se existe uma produção A αbβ diferente 2. Se existe uma produção A αbβ e β é diferente de então tudo que estiver em PRIMEIRO(β), de ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm (β ε), então tudo onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) que está em Seguinte(A) está em Seguinte(B) Primeiro (E) = Primeiro(T) = Primeiro(F) = {(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} Regra 3 Seguinte(E) = {), $} Seguinte(E ) = Seguinte(E) = {), $} Seguinte(T) = Primeiro(E ) = {+} U Seguinte(E) U Seguinte(E ) = {+,), $} Seguinte(T ) = Seguinte(T)= {+,), $} Seguinte(F) = primeiro(t') = {*} U Seguinte(T) U Seguinte(T ) = {*,+,), $} 41
42 Seguinte (Follow) Seguinte(A)=x para a regra SαAβ e primeiro(β)=x E TE E +TE ε T FT T *FT ε F (E) id 1. Colocar $ em Seguinte(S) se S é o símbolo de partida 2. Se existe uma produção A αbβ e β é diferente de ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ Primeiro (E) = Primeiro(T) = Primeiro(F) = {(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} Regras 2 e 3 Seguinte(E) = {), $} Seguinte(E ) = Seguinte(E) = {), $} Seguinte(T) = Primeiro(E ) = {+} U Seguinte(E) U Seguinte(E ) = {+,), $} Seguinte(T ) = Seguinte(T)= {+,), $} Seguinte(F) = primeiro(t') = {*} U Seguinte(T) U Seguinte(T ) = {*,+,), $} onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 42
43 Seguinte (Follow) Seguinte(A)=x para a regra SαAβ e primeiro(β)=x E TE E +TE ε T FT T *FT ε F (E) id 1. Colocar $ em Seguinte(S) se S é o símbolo de partida - $ é o marcador de fim de entrada 2. Se existe uma produção A αbβ e β é diferente de ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ Primeiro (E) = Primeiro(T) = Primeiro(F) = {(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} Regra 3 Seguinte(E) = {), $} Seguinte(E ) = Seguinte(E) = {), $} Seguinte(T) = Primeiro(E ) = {+} U Seguinte(E) U Seguinte(E ) = {+,), $} Seguinte(T ) = Seguinte(T)= {+,), $} Seguinte(F) = primeiro(t') = {*} U Seguinte(T) U Seguinte(T ) = {*,+,), $} onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 43
44 Seguinte (Follow) Seguinte(A)=x para a regra SαAβ e primeiro(β)=x E TE E +TE ε T FT T *FT ε F (E) id 1. Colocar $ em Seguinte(S) se S é o símbolo de partida - $ é o marcador de fim de entrada 2. Se existe uma produção A αbβ e β é diferente de ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ Primeiro (E) = Primeiro(T) = Primeiro(F) = {(, id} Primeiro (E ) = {+, ε} Primeiro (T) = Primeiro(F) = {(, id} Primeiro (T ) = {*, ε} Primeiro (F) = {(, id} Regras 2 e 3 Seguinte(E) = {), $} Seguinte(E ) = Seguinte(E) = {), $} Seguinte(T) = Primeiro(E ) = {+} U Seguinte(E) U Seguinte(E ) = {+,), $} Seguinte(T ) = Seguinte(T)= {+,), $} Seguinte(F) = primeiro(t') = {*} U Seguinte(T) U Seguinte(T ) = {*,+,), $} onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 44
45 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε c) S A BC A aas D B bb fac ε C cc D gd C ε d) S aa bb A aas BD B bb fac ε C cc Dd D gd C ε Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 45
46 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} Primeiro(A)= Primeiro(B)= Primeiro(C)= Primeiro(D)= Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 46
47 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} Primeiro(B)= Primeiro(C)= Primeiro(D)= Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(A) Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 47
48 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} Primeiro(B)= {b,f, ε} Primeiro(C)= Primeiro(D)= Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(A) Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 48
49 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} Primeiro(B)= {b,f, ε} Primeiro(C)= {c U Primeiro(B) U ε} Primeiro(D)= Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(C) Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(A) Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 49
50 a) S A B A aas BD B bb fac ε C cc BD D gd C ε Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} Primeiro(B)= {b,f, ε} Primeiro(C)= {c U Primeiro(B) U ε} Primeiro(D)= {g U Primeiro(C) U ε} Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(C) Primeiro(B) gera ε, então Primeiro(D) entra em Primeiro(A) Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 50
51 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo a) S A B A aas BD B bb fac ε C cc BD D gd C ε a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} = {a, b, f, g, c, ε} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} = {a, b, f, g, c, ε} Primeiro(B)= {b,f, ε} Primeiro(C)= {c U Primeiro(B) U ε} = {c, b, f, g, ε} Primeiro(D)= {g U Primeiro(C) U ε} = {g,c,b,f, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 51
52 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {} Primeiro(A)= {} Primeiro(B)= {} Primeiro(C)= {} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 52
53 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {} Primeiro(A)= {} Primeiro(B)= {} Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 53
54 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {} Primeiro(A)= {} Primeiro(B)= {b, c, U Primeiro(A)} Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 54
55 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {} Primeiro(A)= {a, ε} Primeiro(B)= {b, c, U Primeiro(A)} Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 55
56 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {} Primeiro(A)= {a, ε} Primeiro(B)= {b, c, U Primeiro(A)} = {b, c, a, ε} Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 56
57 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {Primeiro(A) U Primeiro(B) U d} Primeiro(A)= {a, ε} Primeiro(B)= {b, c, U Primeiro(A)} = {b, c, a, ε} Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. Primeiro(A) gera ε, então Primeiro(B) entra em Primeiro(S) e Primeiro(B) gera ε, então d também entra em Primeiro(S) 57
58 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Primeiro(S)= {a, b, c, d, ε} Primeiro(A)= {a, ε} Primeiro(B)= {b, c, a, ε } Primeiro(C)= {c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 58
59 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo c) S A BC A aas D B bb fac ε C cc D gd C ε Primeiro(S)= {} Primeiro(A)= {} Primeiro(B)= {} Primeiro(C)= {} Primeiro(D)= {} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 59
60 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo c) S A BC A aas D B bb fac ε C cc D gd C ε Primeiro(S)= {a, g, c, b, f, ε} Primeiro(A)= {a, g, c, ε} Primeiro(B)= {b, f, ε} Primeiro(C)= {c} Primeiro(D)= {g, c, ε} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 60
61 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo d) S aa bb A aas BD B bb fac ε C cc Dd D gd C ε Primeiro(S)= {} Primeiro(A)= {} Primeiro(B)= {} Primeiro(C)= {} Primeiro(D)= {} Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 61
62 Exercícios Encontre os conjuntos Primeiro(First) para as gramáticas abaixo d) S aa bb A aas BD B bb fac ε C cc Dd D gd C ε Primeiro(S)= {a,b} Primeiro(A)= {a, b, f, g, c, d, ε} Primeiro(B)= {b, f, ε} Primeiro(C)= {g, c, d, ε} Primeiro(D)= {c, g, d, ε } Quando tem uma regra do tipo A BCD, o ε só entra no Primeiro(A) se ele puder ser gerado por B, C e D também. 62
63 Exercícios Encontre os conjuntos Seguinte(Follow) para as gramáticas abaixo a) S A B A aas BD B bb fac ε C cc BD D gd C ε b) S ABd A aa ε B bb ca AC C cb ε c) S A BC A aas D B bb fac ε C cc D gd C ε d) S aa bb A aas BD B bb fac ε C cc Dd D gd C ε 63
64 Exercícios Encontre os conjuntos Seguinte(Follow) para as gramáticas abaixo a) S A B A aas BD B bb fac ε C cc BD D gd C ε Seguinte(S)= Seguinte(A) = {a, b, f, g, c, $} Seguinte(A)= Primeiro(S) U Primeiro(C) = {a, b, f, g, c, $} Seguinte(B)= Primeiro(D) U Seguinte(S) = {g, c, b, f, a, $} Seguinte(C)= Seguinte(B) U Seguinte(D) = {g, c, b, f, a, $} Seguinte (D)= Seguinte(C) U Seguinte(A) = {a, b, f, g, c, $} a) Primeiro(S)= {Primeiro(A) U Primeiro(B)} = {a, b, f, g, c, ε} Primeiro(A)= {a U Primeiro(B) U ε U Primeiro(D)} = {a, b, f, g, c, ε} Primeiro(B)= {b,f, ε} Primeiro(C)= {c U Primeiro(B) U ε} = {c, b, f, g, ε} Primeiro(D)= {g U Primeiro(C) U ε} = {g,c,b,f, ε} Se A é um não-terminal, Seguinte(A) é o conjunto de terminais que podem figurar imediatamente à direita de A em alguma forma sentencial Seguinte(A)=x para a regra SαAβ e primeiro(β)=x Para determinar o Seguinte 1. Colocar $ em Seguinte(S) se S é o símbolo de partida 2. Se existe uma produção A αbβ e β ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 64
65 Exercícios Encontre os conjuntos Seguinte(Follow) para as gramáticas abaixo b) S ABd A aa ε B bb ca AC C cb ε Seguinte(S)= {$} Seguinte(A)= Primeiro(B) U Seguinte(B) U Primeiro(C) = {b, c, a, d, $} Seguinte(B)= Primeiro(d) U Seguinte(C) = {d} Seguinte(C)= Seguinte(B) = {d} Primeiro(S)= {a, b, c, d} Primeiro(A)= {a, ε} Primeiro(B)= {b, c, a, ε } Primeiro(C)= {c, ε} Se A é um não-terminal, Seguinte(A) é o conjunto de terminais que podem figurar imediatamente à direita de A em alguma forma sentencial Seguinte(A)=x para a regra SαAβ e primeiro(β)=x Para determinar o Seguinte 1. Colocar $ em Seguinte(S) se S é o símbolo de partida 2. Se existe uma produção A αbβ e β ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 65
66 Exercícios Encontre os conjuntos Seguinte(Follow) para as gramáticas abaixo c) S A BC A aas D B bb fac ε C cc D gd C ε Seguinte(S)= Seguinte(A) = {a, g, c, b, f, $} Seguinte(A)= Primeiro(S) U Primeiro(C) = {a, g, c, b, f, $} Seguinte(B)= Primeiro(C)={c} Seguinte(C)= Seguinte(B) U Seguinte(D) U Seguinte(S) = {a, g, c, b, f, $} Seguinte (D)= Seguinte(A) = {a, g, c, b, f, $} Primeiro(S)= {a, g, c, b, f, ε} Primeiro(A)= {a, g, c, ε} Primeiro(B)= {b, f, ε} Primeiro(C)= {c} Primeiro(D)= {g, c, ε} Se A é um não-terminal, Seguinte(A) é o conjunto de terminais que podem figurar imediatamente à direita de A em alguma forma sentencial Seguinte(A)=x para a regra SαAβ e primeiro(β)=x Para determinar o Seguinte 1. Colocar $ em Seguinte(S) se S é o símbolo de partida 2. Se existe uma produção A αbβ e β ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 66
67 Exercícios Encontre os conjuntos Seguinte(Follow) para as gramáticas abaixo d) S aa bb A aas BD B bb fac ε C cc Dd D gd C ε Seguinte(S)= Seguinte(A) = {a, b, g, c, d, $} Seguinte(A)= Primeiro(S) U Primeiro(C) = {a, b, g, c, d, $} Seguinte(B)= Primeiro(D) U Seguinte(S) = {a, b, g, c, d, $} Seguinte(C)= Seguinte(B) U Seguinte(D) = {a, b, g, c, d, $} Seguinte (D)= {d} U Seguinte(A) = {a, b, g, c, d, $} Primeiro(S)= {a,b} Primeiro(A)= {a, b, f, g, c, d, ε} Primeiro(B)= {b, f, ε} Primeiro(C)= {g, c, d, ε} Primeiro(D)= {g, c, d, ε } Se A é um não-terminal, Seguinte(A) é o conjunto de terminais que podem figurar imediatamente à direita de A em alguma forma sentencial Seguinte(A)=x para a regra SαAβ e primeiro(β)=x Para determinar o Seguinte 1. Colocar $ em Seguinte(S) se S é o símbolo de partida 2. Se existe uma produção A αbβ e β ε então tudo que estiver em PRIMEIRO(β), exceto ε, deve ser adicionado em Seguinte(B) 3. Se existe uma produção A αb ou A αbβ onde PRIMEIRO(β) contêm ε (β ε), então tudo que está em Seguinte(A) está em Seguinte(B) 67
68 Exercícios 1. Encontre os conjuntos First e Follow para as gramáticas abaixo S(L) a S0S1 01 SS+S SS (S) S* a L L, S S Exemplo String: Exemplo String: Exemplo String: (a+a)*a ((a,a),(a(a)) 2. Encontre os conjuntos First e Follow para a gramática LALG. Enviar até o dia 04/10 68
LFA Aula 09. Gramáticas e Linguagens Livres de Contexto 18/01/2016. Linguagens Formais e Autômatos. Celso Olivete Júnior.
LFA Aula 09 Gramáticas e Linguagens Livres de Contexto (Hopcroft, 2002) 18/01/2016 Celso Olivete Júnior [email protected] www.fct.unesp.br/docentes/dmec/olivete/lfa 1 Classes Gramaticais Linguagens
Hierarquia de Chomsky Exemplos de gramáticas
Hierarquia de Chomsky Exemplos de gramáticas 1 Formalmente, as gramáticas são caracterizadas como quádruplas ordenadas G = ( Vn, Vt, P, S) onde: Vn representa o vocabulário não terminal da gramática. Este
Gramática. Gramática. Gramática
Prof. Yandre Maldonado - 1 Prof. Yandre Maldonado e Gomes da Costa [email protected] Prof. Yandre Maldonado - 2 Mecanismo gerador que permite definir formalmente uma linguagem; Através de uma gramática
Linguagens Formais. Aula 01 - Conceitos Básicos. Prof. Othon Batista Mestre em Informática
Linguagens Formais Aula 01 - Conceitos Básicos Prof. Othon Batista Mestre em Informática Sumário Introdução à Linguagem Alfabeto Cadeias de Símbolos, Palavras Tamanho de Palavra Prefixo, Sufixo ou Subpalavra
Disciplina: LINGUAGENS FORMAIS, AUTÔMATOS E COMPUTABILIDADE Prof. Jefferson Morais
UNIVERSIDADE FEDERAL DO PARÁ INSTITUTO DE CIÊNCIAS EXATAS E NATURAIS FACULDADE DE COMPUTAÇÃO CURSO DE BACHARELADO EM CIÊNCIA DA COMPUTAÇÃO Disciplina: LINGUAGENS FORMAIS, AUTÔMATOS E COMPUTABILIDADE Prof.
Linguagens Formais e Autômatos 02/2015. LFA Aula 02. introdução 28/09/2015. Celso Olivete Júnior.
LFA Aula 02 Linguagens regulares - introdução 28/09/2015 Celso Olivete Júnior [email protected] 1 Na aula passada... Visão geral Linguagens regulares expressões regulares autômatos finitos gramáticas
Parsing Preditivo. Antes de ser abordado o Parsing Preditivo, será apresentado o Analisador Sintático Descendente Recursivo.
UPE Caruaru Sistemas de Informação Disciplina: Compiladores Prof.: Paulemir G. Campos Parsing Preditivo Antes de ser abordado o Parsing Preditivo, será apresentado o Analisador Sintático Descendente Recursivo.
Definições Exemplos de gramáticas
Definições Exemplos de gramáticas 1 Gramáticas Conceito introduzido pela lingüística Objetivo de ensinar o inglês pelo computador e conseguir um tradutor de línguas Fracasso da tradução por volta dos anos
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação - P. Blauth Menezes
COMPILADORES. Análise sintática. Prof. Geovane Griesang Universidade de Santa Cruz do Sul UNISC Departamento de informática
Universidade de Santa Cruz do Sul UNISC Departamento de informática COMPILADORES Análise sintática Parte 02 Prof. [email protected] Data Conteúdo 23/09/2013 3. Análise Sintática: 3.1 analisadores
Análise Sintática. Fabiano Baldo
Compiladores Análise Sintática Fabiano Baldo Gramáticas Livre de Contexto (GLC) É utilizada na especificação formal lda sintaxe de uma linguagem de programação. É um conjunto de produções ou regras gramaticais
Definições Hierarquia de Chomsky Exemplos de gramáticas
Definições Hierarquia de Chomsky Exemplos de gramáticas 1 Formalmente, as gramáticas são caracterizadas como quádruplas ordenadas G = ( Vn, Vt, P, S) onde: Vn representa o vocabulário não terminal da gramática.
Análise Sintática II: Analisadores Descendentes Preditivos
Análise Sintática II: Analisadores Descendentes Preditivos Exercícios LL(1) = Left to right, Left-most derivation, 1 símbolo look-ahead 1. LL(1): definição 2. Para toda produção A -> α β Se β =>* λ, então
Definições Hierarquia de Chomsky Exemplos de gramáticas
Definições Hierarquia de Chomsky Exemplos de gramáticas 1 Formalmente, as gramáticas são caracterizadas como quádruplas ordenadas G = ( Vn, Vt, P, S) onde: Vn representa o vocabulário não terminal da gramática.
Como construir um compilador utilizando ferramentas Java
Como construir um compilador utilizando ferramentas Java p. 1/2 Como construir um compilador utilizando ferramentas Java Aula 2 BNF e Grafo Sintático Prof. Márcio Delamaro [email protected] Como construir
Gramáticas Livres de Contexto Parte 1
Universidade Estadual de Feira de Santana Engenharia de Computação Gramáticas Livres de Contexto Parte 1 EXA 817 Compiladores Prof. Matheus Giovanni Pires O papel do Analisador Sintático É responsável
Conceitos Básicos. Vocabulário Cadeias Linguagens Expressões Regulares Problema X Linguagem
Conceitos Básicos Vocabulário Cadeias Linguagens Expressões Regulares Problema X Linguagem Alfabeto ou Vocabulário: Conjunto finito não vazio de símbolos. Símbolo é um elemento qualquer de um alfabeto.
Linguagens Formais e Autômatos 02/2016. LFA Aula 01 24/10/2016. Celso Olivete Júnior.
LFA Aula 01 Apresentação 24/10/2016 Celso Olivete Júnior [email protected] 1 Professor Celso Olivete Júnior Bacharelado em Ciência da Computação (Unoeste-2002) Mestrado e Doutorado em Engenharia Elétrica
Análise Sintática (Cap. 04) Análise Sintática Descendente
(Cap. 04) Análise Sintática Descendente Análise Sintática Análise sintática descendente Constrói a árvore de derivação de cima para baixo, da raíz para as folhas, criando os nós da árvore em pré ordem
Construção de Compiladores
Construção de Compiladores Parte 1 Introdução Linguagens e Gramáticas F.A. Vanini IC Unicamp Klais Soluções Motivação Porque compiladores? São ferramentas fundamentais no processo de desenvolvimento de
Plano da aula. Compiladores. Os erros típicos são sintáticos. Análise Sintática. Usando Gramáticas. Os erros típicos são sintáticos
Plano da aula Compiladores Análise sintática (1) Revisão: Gramáticas Livres de Contexto 1 Introdução: porque a análise sintática? Noções sobre Gramáticas Livres de Contexto: Definição Propriedades Derivações
Gramáticas e Linguagens independentes de contexto
Capítulo 6 Gramáticas e Linguagens independentes de contexto 6.1 Gramáticas Nesta secção vamos introduzir gramáticas formais para caracterização das linguagens, estudando fundamentalmente as gramáticas
LINGUAGENS FORMAIS Definições. Desenvolveram-se na História em função da necessidade dos grupos humanos que as empregavam
Linguagens Naturais LINGUAGENS FORMAIS Definições Desenvolveram-se na História em função da necessidade dos grupos humanos que as empregavam São muito ricas, mas também ambíguas e imprecisas. Ex.: João
LINGUAGENS FORMAIS E AUTÔMATOS
LINGUAGENS FORMAIS E AUTÔMATOS O objetivo deste curso é formalizar a idéia de linguagem e definir os tipos de sintaxe e semântica. Para cada sintaxe, analisamos autômatos, ue são abstrações de algoritmos.
Construção de Compiladores Aula 16 - Análise Sintática
Construção de Compiladores Aula 16 - Análise Sintática Bruno Müller Junior Departamento de Informática UFPR 25 de Setembro de 2014 1 Introdução Hierarquia de Chomsky Reconhecedores Linguagens Livres de
Compiladores. Análise lexical. Plano da aula. Motivação para análise lexical. Vocabulário básico. Estrutura de um compilador
Estrutura de um compilador programa fonte Compiladores Análise lexical () Expressões Regulares analisador léxico analisador sintático analisador semântico análise gerador de código intermediário otimizador
Alfabeto, Cadeias, Operações e Linguagens
Linguagens de Programação e Compiladores - Aula 3 1 Alfabeto, Cadeias, Operações e Linguagens 1.Conjuntos Para representar um determinado conjunto é necessário buscar uma notação para representá-lo e ter
Apostila 03 - Linguagens Livres de Contexto Exercícios
Cursos: Bacharelado em Ciência da Computação e Bacharelado em Sistemas de Informação Disciplinas: (1493A) Teoria da Computação e Linguagens Formais, (4623A) Teoria da Computação e Linguagens Formais e
Análise Sintática Introdução
Análise Sintática Introdução Renato Ferreira Linguagens e Automatas Linguagens formais são importantes em Computação Especialmente em linguagens de programação Linguagens regulares A linguagem formal mais
Gramáticas ( [HMU00], Cap. 5.1)
Gramáticas ( [HMU00], Cap. 5.1) Vimos que a seguinte linguagem não é regular L = {0 n 1 n n 0} Contudo podemos fácilmente dar uma definição indutiva das suas palavras: 1. ɛ L 2. Se x L então 0x1 L L é
Linguagens Formais e Autômatos. Conceitos Básicos Prof. Anderson Belgamo
Linguagens Formais e Autômatos Conceitos Básicos Prof. Anderson Belgamo Introdução Teoria das Linguagens Formais Originariamente desenvolvida na década de 1950. Objetivo inicial: desenvolver teorias relacionadas
INE5317 Linguagens Formais e Compiladores AULA 9: Propriedades e Reconhecimento das Linguagens Livres do Contexto
INE5317 Linguagens Formais e Compiladores AULA 9: Propriedades e Reconhecimento das Linguagens Livres do Contexto baseado em material produzido pelo prof Paulo Bauth Menezes e pelo prof Olinto José Varela
Apostila 01 Fundamentação da Teoria da Computação e Linguagens Formais
Cursos: Bacharelado em Ciência da Computação e Bacharelado em Sistemas de Informação Disciplinas: (1493A) Teoria da Computação e Linguagens Formais, (4623A) Teoria da Computação e Linguagens Formais e
Gramática regular. IBM1088 Linguagens Formais e Teoria da Computação. Evandro Eduardo Seron Ruiz Universidade de São Paulo
Gramática regular IBM1088 Linguagens Formais e Teoria da Computação Evandro Eduardo Seron Ruiz [email protected] Universidade de São Paulo E.E.S. Ruiz (USP) LFA 1 / 41 Frase do dia Através de três métodos
Conceitos Básicos. Vocabulário Cadeias Linguagens Problema
Conceitos Básicos Vocabulário Cadeias Linguagens Problema Alfabeto ou Vocabulário: Conjunto finito não vazio de símbolos. Símbolo é um elemento qualquer de um alfabeto. Ex: {A,B,C,.Z} alfabeto latino (maiúsculas)
Capítulo 3: Gramáticas
Capítulo 3: Gramáticas Já vimos que procedimentos podem ser usados para definir linguagens de duas maneiras essenciais: como geradores, procedimentos que enumeram os elementos da linguagem, e como reconhecedores
Linguagens Regulares. Prof. Daniel Oliveira
Linguagens Regulares Prof. Daniel Oliveira Linguagens Regulares Linguagens Regulares ou Tipo 3 Hierarquia de Chomsky Linguagens Regulares Aborda-se os seguintes formalismos: Autômatos Finitos Expressões
Linguagens Livres de Contexto
Universidade Católica de Pelotas Centro Politécnico Bacharelado em Ciência da Computação 364018 Linguagens Formais e Autômatos TEXTO 4 Linguagens Livres de Contexto Prof. Luiz A M Palazzo Maio de 2011
Se o símbolo inicial não fizer parte do conjunto de símbolos férteis, a linguagem gerada pela gramática é vazia.
Transformações em G.L.C Uma vez que existem métodos de análise, cada qual exigindo gramáticas com características específicas é importante que uma gramática possa ser transformada, porém, sem perder a
Capítulo 1: Alfabetos, cadeias, linguagens
Capítulo 1: Alfabetos, cadeias, linguagens Símbolos e alfabetos. Um alfabeto é, para os nossos fins, um conjunto finito não vazio cujos elementos são chamados de símbolos. Dessa maneira, os conceitos de
Compiladores I Prof. Ricardo Santos (cap 3 Análise Léxica: Introdução, Revisão LFA)
Compiladores I Prof. Ricardo Santos (cap 3 Análise Léxica: Introdução, Revisão LFA) Análise Léxica A primeira fase da compilação Recebe os caracteres de entrada do programa e os converte em um fluxo de
Compiladores Aula 5. Celso Olivete Júnior. [email protected]
Aula 5 Celso Olivete Júnior [email protected] Na aula passada Conjuntos Primeiro(First) e Seguidor(Follow) 2 Na aula de hoje Análise Sintática Análise Sintática Descendente Recursividade Fatoração 3
Prof. Adriano Maranhão COMPILADORES
Prof. Adriano Maranhão COMPILADORES LINGUAGENS: INTERPRETADAS X COMPILADAS Resumo: Linguagem compilada: Se o método utilizado traduz todo o texto do programa, para só depois executar o programa, então
TEORIA DAS LINGUAGENS 3. GRAMÁTICAS INDEPENDENTES DE CONTEXTO
LICENCIATURA EM CIÊNCIAS DA COMPUTAÇÃO TEORIA DAS LINGUAGENS 3. GRAMÁTICAS INDEPENDENTES DE CONTEXTO José Carlos Costa Dep. Matemática e Aplicações Universidade do Minho Braga, Portugal 31 de Maio de 2010
Concurso Público para provimento de cargo efetivo de Docentes. Edital 20/2015 CIÊNCIA DA COMPUTAÇÃO II Campus Rio Pomba
Questão 01 No processo de construção de compiladores, é essencial compreender e manipular as expressões regulares e suas equivalências. Dentro desse contexto, seja o alfabeto = {a, b, c, d, e} e a seguinte
Linguagens Formais e Autômatos
Linguagens Formais e Autômatos Prof. Yandre Maldonado - 1 Prof. Yandre Maldonado e Gomes da Costa Introdução Problema: definir um conjunto de cadeias de símbolos; Prof. Yandre Maldonado - 2 Exemplo: conjunto
Compiladores Analisador Sintático. Prof. Antonio Felicio Netto Ciência da Computação
Compiladores Analisador Sintático Prof. Antonio Felicio Netto [email protected] Ciência da Computação 1 Análise Sintática - A Análise Sintática constitui a segunda fase de um tradutor de uma
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Linguagens Formais e Autômatos - P. Blauth Menezes 1 Linguagens
Compiladores - Análise Léxica
Compiladores - Análise Léxica Fabio Mascarenhas 2017.2 http://www.dcc.ufrj.br/~fabiom/comp Introdução Primeiro passo do front-end: reconhecer tokens Tokens são as palavras do programa O analisador léxico
Teoria da Computação. Unidade 3 Máquinas Universais. Referência Teoria da Computação (Divério, 2000)
Teoria da Computação Referência Teoria da Computação (Divério, 2000) 1 L={(0,1)*00} de forma que você pode usar uma Máquina de Turing que não altera os símbolos da fita e sempre move a direita. MT_(0,1)*00=({0,1},{q
Disciplina: LINGUAGENS FORMAIS, AUTÔMATOS E COMPUTABILIDADE Prof. Jefferson Morais
UNIVERSIDADE FEDERAL DO PARÁ INSTITUTO DE CIÊNCIAS EXATAS E NATURAIS FACULDADE DE COMPUTAÇÃO CURSO DE BACHARELADO EM CIÊNCIA DA COMPUTAÇÃO Disciplina: LINGUAGENS FORMAIS, AUTÔMATOS E COMPUTABILIDADE Prof.
Lista de exercícios 1
UNIVERSIDADE FEDERAL DO ESPÍRITO SANTO CENTRO DE CIÊNCIAS AGRÁRIAS CCA/ UFES Departamento de Engenharia Rural Lista de exercícios 1 Disciplina: Linguagens Formais e Autômatos Professora: Juliana Pinheiro
SCC Capítulo 1 Linguagens Regulares e Autômatos Finitos
SCC-505 - Capítulo 1 Linguagens Regulares e Autômatos Finitos João Luís Garcia Rosa 1 1 Departamento de Ciências de Computação Instituto de Ciências Matemáticas e de Computação Universidade de São Paulo
INE5317 Linguagens Formais e Compiladores AULA 3: Introdução a Teoria da Computação
INE5317 Linguagens Formais e Compiladores AULA 3: Introdução a Teoria da Computação bas eado em material produzido pelo prof Olinto Jos é Varela Furtado Ricardo Azambuja Silveira INE-CTC-UFSC E-Mail: [email protected]
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO Prof.ª Danielle Casillo Diferencia-se das máquinas de Turing e Post principalmente pelo fato de possuir a memória de entrada separada
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO TEORIA DA COMPUTAÇÃO Aula 02 Introdução à Teoria da Computação Prof.ª Danielle Casillo Linguagem: é uma forma precisa de expressar
Construção de Compiladores Aula 3 - Analisador Sintático
Construção de Compiladores Aula 3 - Analisador Sintático Bruno Müller Junior Departamento de Informática UFPR 20 de Agosto de 2014 Definição A análise sintática (parsing) é um processo que verifica se
Teoria da Computação. Máquinas Universais Máquina com Pilhas
Máquinas Universais Máquina com Pilhas Cristiano Lehrer Introdução A Máquina com Pilhas diferencia-se das Máquinas de Turing e de Post principalmente pelo fato de possuir uma memória de entrada separada
Linguagens Formais e Autômatos (LFA)
Linguagens Formais e Autômatos (LFA) Aula de 28/08/2013 Sobre as respostas das duplas aos exercícios cios propostos 1 Fatos extraídos dos scores das duplas Tempo médio de resposta - A série inteira de
Revisão de GLC e Analisadores Descendentes
Conteúdo da aula 1. xemplos de Gramáticas Revisão de GLC e Analisadores Descendentes Marcelo Johann 2. Propriedades: Ambíguas, sem ciclos, ε-livres, fatoradas à esquerda, recursivas à esquerda, simplificadas
Prova 1 de INF1626 Linguagens Formais e Autômatos
Prova 1 de INF1626 Linguagens Formais e Autômatos Aluno(a): Matrícula: Atenção: O tempo total de prova é de 110 minutos (09:05 às 10:55). Durante a prova não é permitido o uso de qualquer aparelho eletrônico
Conceitos de Linguagens de Programação
Conceitos de Linguagens de Programação Aula 04 Sintaxe e Semântica Edirlei Soares de Lima Sintaxe e Semântica A descrição de uma linguagem de programação envolve dois aspectos principais:
Analisadores Sintáticos LR
FACULDADE ANGLO AMERICANO FOZ DO IGUAÇU Curso de Ciência da Computação 7º Periodo Disciplina: Compiladores Prof. Erinaldo Sanches Nascimento Analisadores Sintáticos LR SLR LR Canônicos LALR Analisadores
O uso de gramáticas traz vantagens para projetistas de linguagens e escritores de compiladores pelas seguintes razões:
3. ANÁLISE SINTÁTICA INTRODUÇÃO Toda linguagem de programação tem regras que descrevem sua estrutura sintática (ou sintaxe). A sintaxe de uma LP pode ser descrita por uma gramática livre de contexto 1
Análise sintática. Análise sintática. Top-down ou descendente. Com retrocesso: por tentativa e erro. Preditiva: para gramáticas LL(1) 09/04/2012
Análise sintática Função, interação com o compilador Análise descendente e ascendente Especificação e reconhecimento de cadeias de tokens válidas Implementação Tratamento de erros Prof. Thiago A. S. Pardo
Compiladores. Top-Down x Bottom Up. Plano da aula. Redução exemplo 1. Redução exemplo 1. Lembrando: construir a tabela de análise LL(1) A Abc b B d
Compiladores Análise sintática ) Análise ascendente Autômatos Empilhar/Reduzir Lembrando: construir a tabela de análise LL) Como fazer? Re-escrever gramática para satisfazer condições de LL) Calcular conjuntos
Análise Sintática (Cap. 04) Análise Sintática Ascendente Analisador Sintático LR
Análise Sintática (Cap. 04) Análise Sintática Ascendente Analisador Sintático LR Análise Sintática LR Analisadores sintáticos LR(k): L, verificação da entrada da esquerda para direita R, constrói a derivação
COMPILADORES. Análise sintática. Prof. Geovane Griesang Universidade de Santa Cruz do Sul UNISC Departamento de informática
Universidade de Santa Cruz do Sul UNISC Departamento de informática COMPILADORES Análise sintática Parte 04 Prof. [email protected] Data Conteúdo 23/09/2013 3. Análise Sintática: 3.1 analisadores
INE5317 Linguagens Formais e Compiladores AULA 5: Autômatos Finitos
INE5317 Linguagens Formais e Compiladores AULA 5: Autômatos Finitos Ricardo Azambuja Silveira INE-CTC-UFSC E-Mail: [email protected] URL: www.inf.ufsc.br/~silveira As Linguagens e os formalismos representacionais
Transformações úteis para GLC: (1) eliminação de produções nulas; (2) eliminação de produções unitárias; (3) Eliminação de símbolos estéreis e
Transformações úteis para GLC: (1) eliminação de produções nulas; (2) eliminação de produções unitárias; (3) Eliminação de símbolos estéreis e inacessíveis; Forma Normal de Chomsky (FNC) e Forma Normal
Exemplo preliminar. Considere a linguagem dos Palíndromos Lpal:
a n b n 1 Exemplo preliminar Considere a linguagem dos Palíndromos Lpal: radar, Roma é amor, 0110, 11011,... ou seja, quando w = w r Lpal é regular? usando o Lema do Bombeamento: Suponha Lpal regular,
Máquina de Turing Linguagens Sensíveis ao Contexto e Enumeráveis Recursivamente
ESIN/UCPel 058814 Linguagens Formais e Autômatos TEXTO 5 Máquina de Turing Linguagens Sensíveis ao Contexto e Enumeráveis Recursivamente Prof. Luiz A M Palazzo Maio de 2007 0. Introdução A Ciência da Computação
Aula 7: Autômatos com Pilha
Teoria da Computação Segundo Semestre, 2014 Aula 7: Autômatos com Pilha DAINF-UTFPR Prof. Ricardo Dutra da Silva Vamos adicionar um memória do tipo pilha ao nossos autômatos para que seja possível aceitar
Como construir um compilador utilizando ferramentas Java
Como construir um compilador utilizando ferramentas Java p. 1/2 Como construir um compilador utilizando ferramentas Java Aula 6 Análise Sintática Prof. Márcio Delamaro [email protected] Como construir
Um alfabeto é um conjunto de símbolos indivisíveis de qualquer natureza. Um alfabeto é geralmente denotado pela letra grega Σ.
Linguagens O conceito de linguagem engloba uma variedade de categorias distintas de linguagens: linguagens naturais, linguagens de programação, linguagens matemáticas, etc. Uma definição geral de linguagem
Terceira Lista de Exercícios 2004/2...
UFLA Universidade Federal de Lavras Departamento de Ciência da Computação COM162 Linguagens Formais e Autômatos Prof. Rudini Sampaio Monitor: Rodrigo Pereira dos Santos Terceira Lista de Exercícios 2004/2
Autômatos com Pilha: Reconhecedores de LLCs
Autômatos com Pilha: Reconhecedores de LLCs 1 Autômatos com Pilha (AP) Definições alternativas para Linguagens Livres de Contexto Extensão de AFND com uma pilha, que pode ser lida, aumentada e diminuída
Compiladores - Análise LL(1)
Compiladores - Análise LL(1) Fabio Mascarenhas - 2013.1 http://www.dcc.ufrj.br/~fabiom/comp Gramáticas LL(1) Uma gramática é LL(1) se toda predição pode ser feita examinando um único token à frente Muitas
Expressões Regulares e Gramáticas Regulares
Universidade Católica de Pelotas Escola de informática 053212 Linguagens Formais e Autômatos TEXTO 2 Expressões Regulares e Gramáticas Regulares Prof. Luiz A M Palazzo Março de 2007 Definição de Expressão
Introdução à Programação
Introdução à Programação Linguagens de Programação: sintaxe e semântica de linguagens de programação e conceitos de linguagens interpretadas e compiladas Engenharia da Computação Professor: Críston Pereira
Como construir um compilador utilizando ferramentas Java
Como construir um compilador utilizando ferramentas Java p. 1/2 Como construir um compilador utilizando ferramentas Java Aula 4 Análise Léxica Prof. Márcio Delamaro [email protected] Como construir
Propriedades de Linguagens Livres de Contexto. Propriedades de Linguagens Livres de Contexto. Propriedades de Linguagens Livres de Contexto
UNIVESIDADE ESTADUAL DE MAINGÁ DEPATAMENTO DE INFOMÁTICA Prof. Yandre Maldonado - 1 Prof. Yandre Maldonado e Gomes da Costa Prof. Yandre Maldonado - 2 A classe de linguagens livres de contexto é fechada
Compiladores - Gramáticas
Compiladores - Gramáticas Fabio Mascarenhas - 2013.1 http://www.dcc.ufrj.br/~fabiom/comp Análise Sintática A análise sintática agrupa os tokens em uma árvore sintática de acordo com a estrutura do programa
Análise Sintática Bottom-up
MAB 471 2011.2 Análise Sintática Bottom-up http://www.dcc.ufrj.br/~fabiom/comp Recapitulando parsers top-down Constróem árvore sintática da raiz até as folhas Recursão à esquerda faz parsers entrarem em
I.2 Introdução a Teoria da Computação
I.2 Introdução a Teoria da Computação O que é? Fundamento da Ciência da Computação Tratamento Matemático da Ciência da Computação Estudo Matemático da Transformação da Informação Qual sua importância?
Linguagens de Programação Aula 3
Aula 3 Celso Olivete Júnior [email protected] Na aula passada... Classificação das LPs (nível, geração e paradigma) Paradigmas Imperativo, OO, funcional, lógico e concorrente 2/33 Na aula de hoje...
Procedimentos e Algorítmos Programas e Linguagens de Programação Tese de Church-Turing Formas de Representação de Linguagens
Procedimentos e Algorítmos Programas e Linguagens de Programação Tese de Church-Turing Formas de Representação de Linguagens 1 Introdução Estudar computação do ponto de vista teórico é sinônimo de caracterizar
Linguagens livres de contexto e autômatos de pilha
Capítulo 6: Linguagens livres de contexto e autômatos de pilha José Lucas Rangel, maio 1999 6.1 - Introdução. Os aceitadores, ou reconhecedores, das linguagens livres de contexto são os chamados autômatos
Linguagens Formais e Compilação Ficha de exercícios
Linguagens Formais e Compilação Ficha de exercícios Simão Melo de Sousa 1 Linguagens Formais: Construir Frases Exercício 1 Para cada uma das gramáticas G seguintes, (a) descreva a linguagem L(G) gerada
Linguagem (formal) de alfabeto Σ
Linguagem (formal) de alfabeto Σ Linguagem é qualquer subconjunto de Σ, i.e. qualquer conjunto de palavras de Σ Σ = {a, b} {aa, ab, ba, bb} ou {x x {a, b} e x = 2} {a, aa, ab, ba, aaa, aab, aba,...} ou
Compiladores. A seção das regras. Especificação (F)lex. Plano da aula. Escolha das regras. Compilação típica com FLEX
Compilação típica com FLX Compiladores Análise sintática (1) Noções sobre Gramáticas Livres de conteto dição do teto de especificação No arquivo minhas_regras.l 3 partes: Declarações Regras (Rs -> Ação)
TRANSFORMAÇÃO DE GRAMÁTICAS LIVRES DO CONTEXTO PARA EXPRESSÕES REGULARES ESTENDIDAS
TRANSFORMAÇÃO DE GRAMÁTICAS LIVRES DO CONTEXTO PARA EXPRESSÕES REGULARES ESTENDIDAS Acadêmico: Cleison Vander Ambrosi Orientador: José Roque Voltolini da Silva Roteiro da Apresentação Introdução Motivação
