Compiladores/Pautas 2015-2016/Pauta do Projecto: Entrega "zero"

From Wiki**3

< Compiladores‎ | Pautas 2015-2016
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 Os resultados da entrega inicial podem ser revistos, nos horários de dúvidas, até à data da entrega intermédia.

Critérios de Avaliação

LER COM ATENÇÃO

A avaliação da entrega inicial considera a execução de intervenções em duas regiões do código do compilador em desenvolvimento, assim como a gestão do projecto correspondente.

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

Considerando que é um passo crucial na concepção do projecto, a não realização desta entrega conduz automaticamente a uma classificação de 0 (zero) na componente de avaliação relativa ao Projecto e consequente exclusão da avaliação da disciplina no ano lectivo 2015/2016.

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 inicial.

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 2 valores (dos 20 disponíveis para o projecto) associados a esta entrega:

  • gestão do projecto: 0.5 valores
    • projecto com a estrutura correcta no repositório CVS: 0.25 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.25 valores

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

  • Classes dos nós do compilador (completo): 1.0 valores
    • Reutilização dos nós da CDK (simples ajuste do Simple)
    • Definição ou extensão de elementos existentes (simples ajuste do Simple)
    • Definição de novas declarações/definições (variáveis/funções) (completo)
    • Definição de novas instruções (completo)
    • Definição de novas expressões (completo)
    • Definição de outros elementos (completo)
    • Sugere-se (por simplicidade de gestão do código) a separação das várias classes de nós em namespaces coerentes (à la Simple)
    • Não é necessário criar as regras no BYACC para criar os nós (se for feito, é conveniente para o progresso do projecto, mas não é avaliado nesta entrega)
  • Métodos dos "visitors" (completo): 0.5 valores
    • Reutilização de métodos já definidos (simples ajuste do Simple)
    • Definição de todos os métodos do_X (correspondentes ao nó da class X) em todos os visitors (simples extensão do Simple)
    • Métodos novos podem estar vazios, mas devem existir
    • Métodos correspondentes a acções semelhantes às existentes devem ser modelados nos existentes (exemplo, do_program_node -> do_function_definition_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.
  • 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 um nome apropriado).
  • A criação de novos nós não apresenta quaisquer dificuldades (são classes muito simples).
  • Os métodos (na sua maioria, vazios) dos "visitors" são simples paralelos com as classes dos nós e os que não estão vazios são quase 100% reutilizáveis na nova linguagem.
  • O compilador é obrigatoriamente desenvolvido em C++, fazendo-se uso do material de apoio.

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: 2 valores
  • 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): penalização máxima de 1 valor
  • Não utilização de qualquer material obrigatório ou não satisfação dos critérios mínimos: 2 valores e considera-se entrega não realizada (implica exclusão da avaliação)

Legenda

A entrega "zero" vale 2 valores em 20.

Os alunos são encorajados a compreender/verificar/corrigir os problemas reportados, especialmente nos casos em que exista anotação explícita na pauta.

Anotações da tabela
  • CDK copies: cópia de código que já está disponível na CDK (não devem existir estar cópias: devem ser usadas as classes da CDK)
  • program node: o program_node não existe (devia ser function_definition_node ou semelhante)
  • lvals: faltam nós correspondentes a alguns left-values (um left-value é uma entidade que pode estar do lado esquerdo de uma atribuição)
  • index: problemas com o nó de indexação (e.g. não é um lvalue, faltam expressões)
  • funcs: faltam nós correspondentes a funções ou têm problemas: e.g. faltam tipos, têm relações com lvalues (não devem existir)
  • decls: faltam nós correspondentes a declarações ou têm problemas (e.g. confundidas com expressões, problemas com tipos, etc.)
  • exprs: faltam expressões (tipicamente, faltam operadores, chamadas a funções)
  • file/const/import/local: nós que não devem existir
  • types: não foi usada a estrutura basic_type da CDK para representar os tipos de dados da linguagem
  • [outras anotações específicas]: contactar o professor responsável

Pauta

<runphp> echo<<<___EOT___

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

___EOT___; </runphp>