Ciência da Computação, Centro de Informática, (UFPE)
- Professor
- Leopoldo Motta Teixeira (@leopoldomt --- lmt@cin)
- Monitores
- Terça (08h-10h), grad 4
- Sexta (10h-12h), grad 4
Este curso explora os princípios, algoritmos, e estruturas de dados envolvidos na teoria e implementação de compiladores. O conteúdo planejado inclui uma introdução aos princípios e técnicas de construção de compiladores, conceitos básicos da teoria de linguagens, análise léxica, análise sintática, análise semântica, representação de código intermediário, ambientes de execução, análise estática, otimização de código, geração de código.
- Keith Cooper & Linda Torczon. Engineering a Compiler. 2nd Edition, Morgan Kaufmann, 2012
- Alfred Aho, Monica Lam, Ravi Sethi, and Jeffrey Ullman. Compilers: Principles, Techniques, and Tools. 2nd Edition, Addison-Wesley, 2006
- Andrew Appel & Jens Palsberg. Modern Compiler Implementation in Java. 2nd edition, Cambridge University Press, 2003
- Michael Scott. Programming Language Pragmatics. 3rd edition, Morgan Kaufmann, 2009
- Dick Grune & Ceriel J.H. Jacobs. Parsing Techniques. 2nd edition, Springer, 2008
- Terence Parr. Language Implementation Patterns. 1st edition, Pragmatic Bookshelf, 2010
- Terence Parr. The Definitive ANTLR 4 Reference. 2nd edition, Pragmatic Bookshelf, 2013
- Ronald Mak. Writing Compilers and Interpreters: A Modern Software Engineering Approach Using Java. 1st edition, John Wiley & Sons, 2009
O objetivo da disciplina é fornecer fundamentos para desenvolvimento da compreensão da teoria e prática de compiladores, e de questões envolvidas na implementação de linguagens.
Na disciplina, utilizaremos uma mistura de aulas tradicionais com exercícios e tarefas de programação em sala de aula e para casa.
- (
N1
+N2
)/2, onde:N1
=Prova1
(60%) +Exercicios1
(40%)Prova1
= Teste com [assunto dado até o momentoExercicios1
= Tarefas passadas durante primeira unidade
N2
=Prova2
(60%) +Exercicios2
(40%)Prova2
= Teste com [assunto dado a partir de Prova1Exercicios2
= Tarefas passadas durante segunda unidade
Final
: Teste com todo o assunto da matéria
- Observações:
- Entrega fora do prazo: redutor de 1 ponto por dia de atraso.
- Atraso máximo: 1 (uma) semana. Após esse prazo, será dada nota zero para a respectiva atividade de avaliação.
- Trabalhos “CTRL-C + CTRL-V” terão nota zero (vale tanto para cópia de colegas, como para trabalhos copiados da internet).
Atenção! Este plano de ensino está sujeito a alterações durante o semestre, visite frequentemente a página para obter a versão mais atualizada, ou acompanhe os updates no repositório.
# | Data | Assunto | Atividades |
---|---|---|---|
01 | 19.02.19 (ter) | Introdução, admin | --- |
02 | 22.02.19 (sex) | Conceitos Básicos | --- |
03 | 26.02.19 (ter) | Tradução Dirigida por Sintaxe | --- |
04 | 01.03.19 (sex) | Análise Léxica (JFlex) | -- |
-- | 05.03.19 (ter) | FERIADO - Carnaval | --- |
05 | 08.03.19 (sex) | Ferramentas para Análise Léxica (JFlex) | Atividade 1 lançada |
06 | 12.03.19 (ter) | Introdução à Análise Sintática e Top-Down Parsing | --- |
07 | 15.03.19 (sex) | LL(1) Parsing | Atividade 2 lançada |
08 | 19.03.19 (ter) | Bottom-up Parsing LR(0) | Deadline para entrega - Atividade 1 |
09 | 22.03.19 (sex) | Bottom-up Parsing LR(1) e LALR | --- |
10 | 26.03.19 (ter) | Bottom-up Parsing LALR & Introdução à Análise Semântica | --- |
11 | 29.03.19 (sex) | Análise Semântica - ASTs | --- |
-- | 31.03.19 (dom) | --- | Deadline para entrega - Atividade 2 |
12 | 02.04.19 (ter) | Análise Semântica - Visitors | Atividade 3 lançada |
13 | 05.04.19 (sex) | Análise Semântica - Escopo & Type Checking | --- |
14 | 09.04.19 (ter) | Revisão | --- |
15 | 12.04.19 (sex) | 1 Exercício Escolar | --- |
-- | 15.04.19 (seg) | --- | Deadline para entrega - Atividade 3 |
-- | 16.04.19 (ter) | Aula cancelada | |
-- | 19.04.19 (sex) | FERIADO - Paixão de Cristo | --- |
16 | 23.04.19 (ter) | Representações Intermediárias de Código - Código de 3 Endereços | --- |
17 | 26.04.19 (sex) | Control-flow graphs e Introdução à Análise e Otimização de Código | --- |
18 | 30.04.19 (ter) | Otimizações Locais e Globais | --- |
29 | 03.05.19 (sex) | Automatizando Análise Sintática com ANTLR | Atividades 4 e 5 lançadas |
20 | 07.05.19 (ter) | Exercício - Atividades 4 e 5 | --- |
21 | 10.05.19 (sex) | Representações Intermediárias de Código - LLVM | --- |
22 | 14.05.19 (ter) | Otimizações Globais | |
23 | 17.05.19 (sex) | Análise e Otimização de Código | Deadline para entrega - Atividade 4 |
24 | 21.05.19 (ter) | Ambientes de Execução | --- |
25 | 24.05.19 (sex) | Ambientes de Execução | Atividade 6 lançada |
26 | 28.05.19 (ter) | Ambientes de Execução | --- |
27 | 31.05.19 (sex) | Geração de Código | Deadline para entrega - Atividade 5 |
28 | 04.06.19 (ter) | Geração de Código | --- |
29 | 07.06.19 (sex) | Geração de Código | Deadline para entrega - Atividade 6 |
30 | 11.06.19 (ter) | Geração de Código | --- |
31 | 14.06.19 (sex) | 2 Exercício Escolar | --- |
32 | 18.06.19 (ter) | Segunda Chamada | --- |
33 | 21.06.19 (sex) | Tirar dúvidas (online) | --- |
34 | 25.06.19 (ter) | Tirar dúvidas (online) | --- |
34 | 28.06.19 (ter) | Prova Final | --- |