Compiladores/Pautas 2015-2016/Pauta do Projecto: Entrega Intermédia

From Wiki**3

< Compiladores‎ | Pautas 2015-2016
Revision as of 19:06, 19 April 2016 by Root (talk | contribs) (→‎Pauta)
AVISOS - Avaliação em Época Normal

Esclarecimento de dúvidas:

  • Consultar sempre o corpo docente atempadamente: presencialmente ou através do endereço oficial da disciplina [1].
  • Não utilizar fontes de informação não oficialmente associadas ao corpo docente (podem colocar em causa a aprovação à disciplina).
  • Não são aceites justificações para violações destes conselhos: quaisquer consequências nefastas são da responsabilidade do aluno.

Requisitos para desenvolvimento, material de apoio e actualizações do enunciado (ver informação completa em Projecto de Compiladores):

  • O material de apoio é de uso obrigatório e não pode ser alterado.
  • Verificar atempadamente (mínimo de 48 horas antes do final de cada prazo) os requisitos exigidos pelo processo de desenvolvimento.

Processo de avaliação (ver informação completa em Avaliação do Projecto):

  • Datas: 2016/03/18 17:00 (inicial); 2016/04/15 17:00 (intercalar); 2016/05/20 17:00 (final); 2016/05/20-2016/05/27 (teste prático).
  • A entrega inicial, sendo crucial para o projecto, é obrigatória e sua não realização implica a exclusão da avaliação do projecto e, por consequência, da avaliação da disciplina.
  • Verificar atempadamente (até 48 horas antes do final de cada prazo) os requisitos exigidos pelo processo de avaliação, incluindo a capacidade de acesso ao repositório CVS.
  • Apenas se consideram para avaliação os projectos existentes no repositório CVS oficial.
  • Trabalhos não presentes no repositório no final do prazo têm classificação 0 (zero) (não são aceites outras formas de entrega). Não são admitidas justificações para atrasos em sincronizações do repositório. A indisponibilidade temporária do repositório, desde que inferior a 24 horas, não justifica atrasos na submissão de um trabalho.
  • A avaliação do projecto pressupõe o compromisso de honra de que o trabalho correspondente foi realizado pelos alunos correspondentes ao grupo de avaliação.
  • Fraudes na execução do projecto terão como resultado a exclusão dos alunos implicados do processo de avaliação em curso.
Material de Uso Obrigatório
As bibliotecas CDK e RTS de apoio ao desenvolvimento do projecto são de uso obrigatório:
A máquina virtual, fornecida para desenvolvimento do projecto, já contém todo o material de apoio.
Uso Obrigatório: Repositório CVS
Apenas se consideram para avaliação os projectos existentes no repositório CVS oficial.

Trabalhos não presentes no repositório no final do prazo têm classificação 0 (zero) (não são aceites outras formas de entrega). Não são admitidas justificações para atrasos em sincronizações do repositório. A indisponibilidade temporária do repositório, desde que inferior a 24 horas, não justifica atrasos na submissão de um trabalho.

Prazo de Revisão

PAUTA EM ACTUALIZAÇÃO

A entrega intermédia pode ser revista até à data da entrega final do projecto.

Critérios de Avaliação

LER COM ATENÇÃO

A entrega intermédia vale 6 valores em 20.

A avaliação é realizada sobre a versão existente no CVS no final do prazo para a entrega intermédia. Projectos que não apresentem alterações relativamente ao conteúdo inicial do repositório CVS ou relativamente à entrega inicial não serão considerados.

A avaliação da entrega intermédia considera a execução de intervenções em várias regiões do código do compilador em desenvolvimento, assim como a gestão do projecto correspondente.

Advertem-se os alunos sobre a consulta de colegas de anos anteriores. Estas consultas podem ser positivas, mas comportam algum risco, pois o processo e critérios de avaliação podem ter mudado. Além disso, a proficiência do colega pode majorar negativamente o resultado da avaliação em curso. Não são admitidas quaisquer justificações com base na história da disciplina.

Estas condições são aplicáveis à data da entrega intermédia.

Em caso de dúvidas suscitadas por qualquer elemento neste texto, no projecto, ou na disciplina em geral, os alunos são fortemente encorajados a consultar o corpo docente.

VALORAÇÕES

Existem 6 valores (dos 20 disponíveis para o projecto) associados a esta entrega:

  • gestão do projecto: 1 valor
    • projecto com a estrutura correcta no repositório CVS: 0.5 valores (i.e., código que não apresente a estrutura canónica de um compilador desenvolvido com a CDK é considerado sem a estrutura correcta -- consultar estas páginas sobre o desenvolvimento do projecto com base no repositório CVS)
    • projecto compila e produz compilador "zu" ("zu", com letras minúsculas: variações correspondem a "não compilação"): 0.5 valores

Se o projecto compilar, poderão ser atribuídos mais 5 valores (desenvolvimento do compilador), distribuídos como se segue:

  • Flex (completo): 1.5 valores
    • Tokens correspondentes aos símbolos e palavras chave (simples ajuste do Simple)
    • Identificadores (simples ajuste do Simple)
    • Inteiros (deve estar implementada a base 16 -- a base 10 já está implementada no Simple)
    • Reais (extensão dos inteiros)
    • Strings (extensão do Simple)
    • O Flex deve retornar os tokens ao byacc (sobre DEBUG, ver abaixo) -- o não retorno de tokens penaliza fortemente toda a componente Flex (ver penalizações)
  • BYACC (completo): 1 valor
    • Regras correspondentes a literais de reais e strings (simples extensão do Simple)
    • Regras correspondentes a ciclos, etc. (simples extensão e adaptação do Simple)
    • Regras correspondentes a declarações de variáveis
    • Regras correspondentes a declarações/definições de funções
    • As acções correspondentes às regras definidas no BYACC devem estar implementadas (simples criação de nós) -- a não implementação corresponde a penalizações (var abaixo)
  • Nós (nodes) (completo): 1 valor
    • Todos os nós necessários para a linguagem (utilizados na especificação BYACC e em passos subsequentes) devem ser criados
    • A não criação de nós motivada pela ausência de definição de acções no BYACC é penalizada (ver abaixo)
  • Semântica (visitors) (xml_writer completo; postfix_writer ver a seguir): 1.5 valores
    • O "visitor" xml_writer deve estar completamente implementado (ver também DEBUG abaixo)
    • O "visitor" type_checker deve ter todos os métodos (correspondentes aos nós, tal como o xml_writer), embora alguns possam estar ainda vazios (i.e., podem não executar qualquer acção)
    • O "visitor" postfix_writer deve ter todos os métodos (correspondentes aos nós, tal como o xml_writer), embora alguns possam estar ainda vazios (i.e., podem não executar qualquer acção)
    • Métodos correspondentes a acções semelhantes às existentes devem ser modelados nos existentes (exemplo, do_while_node -> do_repeat_node) (mesmo que não modificados numa primeira instância)
    • A presença de implementações de semântica no postfix_writer (tabela de símbolos, validação de tipos, etc.) não é penalizada, mas não será avaliada nesta entrega
PENALIZAÇÕES

Existem penalizações relativas à (deficiente) execução do projecto.

São considerados os seguintes aspectos preliminares:

  1. A linguagem do projecto contém a linguagem Simple, pelo que não há razão para não utilizar completamente o compilador Simple, eventualmente com pequenas alterações.
  2. A semântica da linguagem do projecto contém a da linguagem Simple, pelo que a implementação de alguns aspectos da linguagem do projecto não requer qualquer reimplementação relativamente ao Simple.
  3. O compilador Simple foi fornecido completamente funcional, assim como a versão inicial do compilador do projecto no respositório CVS (igual ao Simple e apenas alterado para ter o nome apropriado).
  4. A criação de novos nós não apresenta quaisquer dificuldades (são classes muito simples)
  5. O código dos métodos do visitor xml_writer corresponde a uma simples impressão dos atributos dos nós, através de uma travessia da árvore que formam e que os contém.
  6. O compilador é obrigatoriamente desenvolvido em C++.

Considerando os aspectos 1. a 6., são aplicadas as seguintes penalizações:

  • Destruição de funcionalidade do compilador Simple sem substituição por funcionalidade equivalente do compilador do projecto: 4 valores

Não definição dos nós para regras BYACC em avaliação (ver acima) ou não utilização de nós definidos para a escrita dessas acções: 2 valores

  • A utilização de funções e estruturas C, quando existem alternativas directas C++ (malloc em lugar de new, por exemplo; strcmp, etc. em lugar da classe std::string; e outras) terá uma penalização máxima de 1 valor
  • Não utilização de qualquer material obrigatório: 6 valores (e considera-se projecto não realizado)

DEBUG

O despiste de problemas em especificações Flex pode ser realizado de forma simples utilizando os métodos descritos em How to Debug a Flex Specification.

O visitor xml_writer foi concebido para produzir uma representação textual hierárquica (árvore XML) correspondente ao programa em compilação. É muito útil para inspeccionar a contrução da árvore de nós por parte do BYACC, permitindo, inclusivamente, a apresentação gráfica.

Legenda

RELATIVAMENTE A NÃO COMPILAR

Todos os problemas de compilação podem e devem ser resolvidos (perdendo-se 0.50 pontos, relativos à componente de compilação).

Os alunos são fortemente encorajados a compreender/verificar/corrigir os problemas reportados. Alunos cujo projecto não compile (e apenas esses), podem solicitar correcção de versão nova a partir do CVS (desconto aplicável). Não se considerarão outras alterações na avaliação intermédia.

As questões relativas às colunas "Problemas" devem ser resolvidas quanto antes (nos horários de dúvidas ou, sendo possível, por correio electrónico).

Problemas na análise lexical
  • .* - uso indevido do padrão
  • bases - problemas com bases (em falta)
  • chars - definição indevida (não existem na linguagem)
  • comments - problemas com comentários (em excesso ou em falta)
  • delims - problemas com delimitadores
  • floats - problemas com vírgula flutuante (definições incompletas)
  • ids - problems com identificadores
  • ints - problemas com inteiros (definições incompletas ou excessivas)
  • keywords - problemas com palavras chave (a mais ou a menos)
  • negative literals - problemas com valores negativos (não existem)
  • ops - problemas com operadores e afins
  • patterns - problemas genéricos com escrita de padrões lexicais
  • strings - problemas na definição de strings (composição, concatenação indevida, etc.)
  • type tokens - problemas com definição de tipos (e.g., uso do mesmo token dos literais)
  • [outros] - casos específicos (contactar professor responsável)
Problemas na análise sintáctica
  • conflicts - conflitos no analisador LALR(1) (não avaliado nesta entrega)
  • decls - problemas nas declarações (e.g. mistura com expressões ou com instruções)
  • empty rules - regras sem semântica associada
  • exprs - problemas nas expressões (em falta ou com inclusão de casos errados)
  • funcalls - problemas nas chamadas a funções (e.g. não estão definidos como expressões)
  • funcs - problemas (vários) nas declarações/definições de funções
  • lvals - problemas na definição de left-values (e.g. ausência de definições ou incompletas)
  • precs - problemas na definição de precedências (tipicamente, em excesso ou sem correspondência com o manual)
  • read - problemas na definição da expressão de leitura (verificar manual de referência)
  • semantics - problemas na definição de acções semânticas
  • (simple) - contém apenas a definição original (linguagem Simple)
  • strings - problemas na definção de cadeias de caracteres
  • syntax - problemas na definição da gramática (verificar manual de referência)
  • [outras anotações] - casos específicos (contactar professor responsável)
Problemas na análise semântica e na geração de código (nós e XML)

Nos nós:

  • lvals - problemas na definição ou uso de left-values
  • decls - problemas na definição de declarações/definições de funções/variáveis
  • read_node - uso de left-value no read_node (não é uma atribuição, pelo que não tem left-values)
  • [outros nós] - nós com problemas (excedentários ou com problemas na definição)
  • [outras anotações] - casos específicos (contactar professor responsável)

No visitor xml_writer:

  • ast - o método "ast" do compilador não foi chamado no parser (.y), pelo que a AST está indefinida
  • empty methods - métodos vazios ou funcionalmente vazios
  • [outras anotações] - casos específicos (contactar professor responsável)

Pauta

PAUTA EM ACTUALIZAÇÃO

<runphp> echo<<<___EOT___

<colgroup width="44"></colgroup> <colgroup span="2" width="43"></colgroup> <colgroup width="37"></colgroup> <colgroup width="87"></colgroup> <colgroup width="37"></colgroup> <colgroup width="90"></colgroup> <colgroup width="37"></colgroup> <colgroup width="134"></colgroup> <colgroup width="38"></colgroup> <colgroup width="119"></colgroup> <colgroup width="38"></colgroup> <colgroup width="104"></colgroup> <colgroup width="38"></colgroup> <colgroup width="85"></colgroup> <colgroup span="2" width="47"></colgroup> <colgroup width="38"></colgroup> <colgroup width="75"></colgroup> <colgroup width="82"></colgroup> <tbody> </tbody>
      Pontos Positivos Pontos Negativos  
  Nota Total CVS Compilação
<a href="https://goo.gl/jtNDjN">https://goo.gl/jtNDjN</a>
Análise Lexical Análise Sintáctica Nós Semântica Simple Nós, etc. Bad code OBS.
Grupo 6.00 6.00 0.50 Problemas 0.50 Problemas 1.50 Problemas 1.00 Problemas 1.00 Problemas 1.50 Problemas -4.00 -2.00 -1.00 Problemas
001 1.00 1.00 1.00   1.00                            
002 1.00 1.00 1.00   1.00                            
003 1.00 1.00 1.00   1.00         conflicts                  
004 1.00 1.00 1.00   1.00         conflicts                  
005 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
006 1.00 1.00 1.00   1.00                            
007 1.00 1.00 1.00   1.00                            
008 1.00 1.00 1.00   1.00         conflicts                  
009 1.00 1.00 1.00   1.00                            
010 1.00 1.00 1.00   1.00         conflicts                  
011 1.00 1.00 1.00   1.00         conflicts                  
012 1.00 1.00 1.00   1.00         conflicts                  
013 1.00 1.00 1.00   1.00                            
014 1.00 1.00 1.00   1.00         conflicts                  
015 1.00 1.00 1.00 README.md 1.00         conflicts                  
016 1.00 1.00 1.00   1.00         conflicts                  
017 1.00 1.00 1.00   1.00         conflicts                  
018 1.00 1.00 1.00   1.00         conflicts                  
019 1.00 1.00 1.00   1.00         conflicts                  
020 1.00 1.00 1.00   1.00         conflicts                  
021 1.00 1.00 1.00   1.00                            
022 1.00 1.00 1.00   1.00         conflicts                  
023 1.00 1.00 1.00   1.00                            
024 1.00 1.00 1.00   1.00         conflicts                  
025 1.00 1.00 1.00   1.00         conflicts                  
026 1.00 1.00 1.00   1.00                            
027 1.00 1.00 1.00   1.00         conflicts                  
028 0.00 0.00 sem entrega intermédia
029 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
030 1.00 1.00 1.00   1.00                            
031 1.00 1.00 1.00   1.00         conflicts                  
032 1.00 1.00 1.00   1.00                            
033 0.00 0.00 sem entrega intermédia
034 1.00 1.00 1.00   1.00         conflicts                  
035 1.00 1.00 1.00   1.00                            
036 1.00 1.00 1.00   1.00                            
037 1.00 1.00 1.00   1.00         conflicts                  
038 1.00 1.00 1.00   1.00                            
039 1.00 1.00 1.00   1.00         conflicts                  
040 1.00 1.00 1.00   1.00                            
041 1.00 1.00 1.00   1.00                            
042 1.00 1.00 1.00   1.00         conflicts                  
043 1.00 1.00 1.00   1.00         conflicts                  
044 1.00 1.00 1.00   1.00         conflicts                  
045 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
046 1.00 1.00 1.00 TODO 1.00         conflicts                  
047 1.00 1.00 1.00   1.00                            
048 1.00 1.00 1.00   1.00         conflicts                  
049 1.00 1.00 1.00 settings 1.00         conflicts                  
050 1.00 1.00 1.00   1.00         conflicts                  
051 1.00 1.00 1.00   1.00         conflicts                  
052 1.00 1.00 1.00   1.00                            
053 1.00 1.00 1.00   1.00                            
054 1.00 1.00 1.00   1.00         conflicts                  
055 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
056 1.00 1.00 1.00   1.00                            
057 1.00 1.00 1.00   1.00         conflicts                  
058 1.00 1.00 1.00   1.00         conflicts                  
059 1.00 1.00 1.00   1.00         conflicts                  
060 1.00 1.00 1.00   1.00         conflicts                  
061 1.00 1.00 1.00   1.00         conflicts                  
062 1.00 1.00 1.00   1.00                            
063 1.00 1.00 1.00   1.00         conflicts                  
064 1.00 1.00 1.00   1.00                            
065 1.00 1.00 1.00   1.00                            
066 1.00 1.00 1.00   1.00                            
067 NA                                    
068 NA                                    
069 0.00 0.00 sem entrega intermédia
070 1.00 1.00 1.00   1.00         conflicts                  
071 1.00 1.00 1.00   1.00         conflicts                  
072 1.00 1.00 1.00   1.00         conflicts                  
073 1.00 1.00 1.00   1.00         conflicts                  
074 1.00 1.00 1.00   1.00         conflicts                  
075 1.00 1.00 1.00   1.00                            
076 1.00 1.00 1.00   1.00                            
077 1.00 1.00 1.00   1.00         conflicts                  
078 1.00 1.00 1.00   1.00         conflicts                  
079 1.00 1.00 1.00   1.00         conflicts                  
080 1.00 1.00 1.00   1.00                            
081 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
082 1.00 1.00 1.00   1.00         conflicts                  
083 1.00 1.00 1.00   1.00         conflicts                  
084 1.00 1.00 1.00   1.00                            
085 1.00 1.00 1.00   1.00         conflicts                  
086 NA                                    
087 1.00 1.00 1.00   1.00         conflicts                  
088 1.00 1.00 1.00   1.00         conflicts                  
089 1.00 1.00 1.00   1.00         conflicts                  
090 1.00 1.00 1.00   1.00         conflicts                  
091 1.00 1.00 1.00 targets 1.00                            
092 1.00 1.00 1.00   1.00                            
093 1.00 1.00 1.00   1.00                            
094 1.00 1.00 1.00   1.00                            
095 1.00 1.00 1.00   1.00         conflicts                  
096 1.00 1.00 1.00   1.00         conflicts                  
097 1.00 1.00 1.00   1.00                            
098 1.00 1.00 1.00   1.00         conflicts                  
099 1.00 1.00 1.00   1.00         conflicts                  
100 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
101 1.00 1.00 1.00   1.00         conflicts                  
102 1.00 1.00 1.00   1.00         conflicts                  
103 1.00 1.00 1.00   1.00                            
104 1.00 1.00 1.00   1.00         conflicts                  
105 1.00 1.00 1.00   1.00         conflicts                  
106 1.00 1.00 1.00   1.00         conflicts                  
107 1.00 1.00 1.00   1.00         conflicts                  
108 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
109 1.00 1.00 1.00   1.00         conflicts                  
110 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
111 1.00 1.00 1.00   1.00                            
112 1.00 1.00 1.00   1.00                            
113 1.00 1.00 1.00   1.00         conflicts                  
114 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
115 1.00 1.00 1.00   1.00                            
116 1.00 1.00 1.00   1.00                            
117 1.00 1.00 1.00   1.00                            
118 1.00 1.00 1.00   1.00         conflicts                  
119 1.00 1.00 1.00   1.00         conflicts                  
120 1.00 1.00 1.00   1.00         conflicts                  
121 1.00 1.00 1.00   1.00                            
122 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
123 1.00 1.00 1.00   1.00         conflicts                  
124 1.00 1.00 1.00   1.00                            
125 NA                                    
126 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
127 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
128 1.00 1.00 1.00   1.00         conflicts                  
129 1.00 1.00 1.00   1.00         conflicts                  
130 0.50 0.50 1.00   0.00 (cvs ok)                          
131 1.00 1.00 1.00   1.00                            
132 1.00 1.00 1.00 readme.txt 1.00         conflicts                  
133 NA                                    
134 1.00 1.00 1.00   1.00                            
135 0.00 0.00 sem entrega intermédia
136 1.00 1.00 1.00   1.00         conflicts                  
137 1.00 1.00 1.00   1.00         conflicts                  
138 1.00 1.00 1.00   1.00         conflicts                  
139 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
140 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
141 1.00 1.00 1.00   1.00                            
142 NA                                    
143 1.00 1.00 1.00   1.00                            
144 1.00 1.00 1.00   1.00         conflicts                  
145 NA                                    
146 1.00 1.00 1.00   1.00                            
147 1.00 1.00 1.00   1.00                            
148 1.00 1.00 1.00   1.00         conflicts                  
149 1.00 1.00 0.75 project.tar 1.00         conflicts                  
150 0.88 0.88 1.00   1.00         conflicts                  
151 1.00 1.00 1.00   1.00                            
152 0.50 0.50 1.00   0.00 (cvs ok)       conflicts                  
153 1.00 1.00 1.00   1.00         conflicts                  
154 1.00 1.00 1.00   1.00                            
155 0.50 0.50 1.00   0.00 não compila       conflicts                 contactar prof. responsável
156 1.00 1.00 1.00   1.00         conflicts                  
157 1.00 1.00 1.00   1.00         conflicts                  
158 NA                                    
159 NA                                    
160 1.00 1.00 1.00   1.00         conflicts                  
161 1.00 1.00 1.00   1.00         conflicts                  
162 1.00 1.00 1.00   1.00         conflicts                  
163 1.00 1.00 1.00   1.00         conflicts                  
164 1.00 1.00 1.00   1.00         conflicts                  
165 1.00 1.00 1.00   1.00         conflicts                  
166 NA                                    
167 1.00 1.00 1.00   1.00         conflicts                  
168 1.00 1.00 1.00   1.00         conflicts                  
169 0.50 0.50 1.00   0.00 não compila       conflicts                 contactar prof. responsável
170 NA                                    
171 0.00 0.00 sem entrega intermédia
172 1.00 1.00 1.00   1.00         conflicts                  
173 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
174 1.00 1.00 1.00   1.00                            
175 1.00 1.00 1.00   1.00         conflicts                  
176 NA                                    
177 1.00 1.00 1.00   1.00                            
178 NA                                    
179 1.00 1.00 1.00   1.00         conflicts                  
180 1.00 1.00 1.00   1.00         conflicts                  
181 1.00 1.00 1.00   1.00         conflicts                  
182 1.00 1.00 1.00   1.00         conflicts                  
183 NA                                    
184 1.00 1.00 1.00   1.00                            
185 1.00 1.00 1.00   1.00         conflicts                  
186 NA                                    
187 1.00 1.00 1.00   1.00         conflicts                  
188 1.00 1.00 1.00   1.00         conflicts                  
189 1.00 1.00 1.00   1.00                            
190 1.00 1.00 1.00   1.00                            
191 1.00 1.00 1.00   1.00         conflicts                  
192 0.00 0.00 sem entrega intermédia
193 0.00 0.00 sem entrega intermédia
194 1.00 1.00 1.00   1.00                            
195 1.00 1.00 1.00   1.00         conflicts                  
196 1.00 1.00 1.00   1.00                            
197 1.00 1.00 1.00   1.00                            
198 0.50 0.50 1.00   0.00 não compila                         contactar prof. responsável
199 1.00 1.00 1.00   1.00                            
200 1.00 1.00 1.00   1.00         conflicts                  
201 NA                                    
202 NA                                    
203 NA                                    

___EOT___; </runphp>