====== Compilers ======
----
===== News =====
  * 6 February 2019: The text and the solution of the written test of Wednesday 06/02/2019 is available in the Exams section below.
  * 24 January 2019: The written test previously scheduled on 31/01/2019 was **moved to Wednesday 06/02/2019 3.00pm**. Please register on ESSE3 by 05/02/2019.
  * 18 January 2019: an **Errata Corrige** has been published regarding the track of the project, please consult the relative section below.
  * 20 December 2018: the lecture cancelled on 19 December 2018 is **rescheduled on Thursday 17 January 2019** (last lecture, exercise session for the written test)
  * 18 December 2018: the lecture of **Wednesday 19 December 2018** is **cancelled**.
  * 17 December 2018: the track of the **project** is online in the relative section. 
  * 09 October 2018: the lectures of **Thursday 25th October 2018** and **Wednesday 31st October 2018** are **cancelled**.
----
===== General Information =====
**Teacher**: 
  * [[http://docenti.unicam.it/pdett.aspx?ids=N&tv=d&UteId=572&ru=RU|Luca Tesei]]
**ESSE3 Link**
  * [[https://didattica.unicam.it/Guide/PaginaADErogata.do?ad_er_id=2018*N0*N0*S1*14607*9980&ANNO_ACCADEMICO=2018&mostra_percorsi=S|Compilers - AY 2018/2019]] 
**Lectures schedule**:
  * Wed 11am-1pm Room AB2 Polo Lodovici, Via Madonna delle Carceri 9, Camerino
  * Thu 11am-1pm Room AB3 Polo Lodovici, Via Madonna delle Carceri 9, Camerino
**Webex Room for Lecture Streaming**
  * [[http://unicam.webex.com/meet/luca.tesei/|Luca Tesei's room]]
**Office hours**:
  * Luca Tesei's office hours are specified [[http://docenti.unicam.it/pdett.aspx?ids=N&tv=d&UteId=572&ru=RU|here]], look at the notices for any variation. The place is Luca Tesei's office, 1st floor, Polo Lodovici, via Madonna delle Carceri 9, Camerino.
----
===== Course Objectives =====
D1 – KNOWLEDGE AND UNDERSTANDING
At the end of the course, the student should be able to:
  - Identify all essential steps for automatically converting source code into assembly or other low-level languages.
  - Explain how programs that process other programs treat the other programs as their input data.
  - Describe the benefits of having program representations other than strings of source code. 
  - Distinguish a language definition (what constructs mean) from a particular language implementation (compiler vs. interpreter, run-time representation of data objects, etc.). 
  - Distinguish syntax and parsing from semantics and evaluation. 
  - Define formally different language recognisers, such as REGEXPs, NFAs, DFAs, CFGs 
  - Illustrate some of the basic algorithms to generate lexical analysers from lexical definitions
  - Illustrate some of the basic algorithms to generate parsers from grammar definitions
  - Identify key issues in syntax definitions: ambiguity, associativity, precedence.
D2 – APPLYING KNOWLEDGE AND UNDERSTANDING
At the end of the course, the student should be able to:
  - Use formal grammars to specify the syntax of languages.
  - Convert among equivalently powerful notations for a language, including among DFAs, NFAs, and regular expressions, and between PDAs and CFGs.
  - Describe an abstract syntax tree for a small language.
  - Write a program to process some representation of code for some purpose, such as an interpreter, an expression optimiser, or a documentation generator.
  - Use declarative tools to generate parsers and scanners. 
  - Implement context-sensitive, source-level static analyses such as type-checkers.
  - Describe semantic analyses using an attribute grammar. 
  - Define useful static analyses in terms of a conceptual framework such as dataflow analysis. 
D3 – MAKING JUDGEMENTS
At the end of the course, the student should be able to:
  - Determine a language’s place in the Chomsky hierarchy (regular, context-free, recursively enumerable).
D4 - COMMUNICATION SKILLS
At the end of the course, the student should be able to:
  - Produce a detailed report on the design and implementation of a project
D5 – LEARNING SKILLS
At the end of the course, the student should be able to:
  - Understand and use any new tool for the automatic generation of lexers and parsers
----
===== Course Contents =====
The course will delve into the following topics (for students convenience chapters in the textbook are indicated within parenthesis)
  * **General Introduction to Compilers construction** [ALSU - Ch.1]
    * Structure of a compiler
    * Evolution of programming languages
    * Generalities on programming languages
  * **Lexical Analysis** [ALSU - Ch.3]
    * Lexical analysis objectives and issues
    * Tokens, patterns, and lexemes
    * Regular expressions and definitions
    * Finite Automata
      * DFA - Deterministic Finite Automata
      * NFA - Non Deterministic Finite Automata
    * From RegExp to NFA
    * From NFA to DFA
    * DFA Minimization
    * Recongnition of tokens
  * **Syntax Analysis** [ALSU - Ch.4]
    * Introduction to CF grammars and Push-Down automata
    * Parse tree and derivations
    * Ambiguity
    * Top-down parsing
      * Left recursion and left factoring
      * Recursive descent parsing
      * FIRST and FOLLOW sets
      * Non recursive predictive parsing
      * Error recovery in predictive parsing
    * Bottom-up parsing
      * Reductions, Handles
      * Shift-reduce parsing
      * LR(0) automaton and table
      * SLR table
      * LR(1) automaton and table
      * LALR table
      * Error recovery in LR parsing
  * **Syntax-Directed Translation ** [ALSU - Ch.5 (section 5.5 excluded)]
    * Syntax-Directed Definitions
    * Inherited and Synthesized Attributes
    * Dependency Graphs
    * Syntax-Directed Translation Schemes
  * **Intermediate Code Generation** [ALSU - Ch. 6 (sections 6.7,6.8,6.9 excluded)
    * Three-Address Code
    * Type Checking
    * Control Flow Translation schemes
----
===== Study Material =====
**Lectures**
  - 03/10/2018 - [[https://unicam.webex.com/unicam/lsr.php?RCID=96b9c9decc6341959fa584a276bbeae4|Watch the Lecture]],  [[https://unicam.webex.com/unicam/lsr.php?RCID=dcbfe9b1c78522e48fc70b6e60584881|Download the Lecture]] (in the first part of the lecture the desktop cannot be seen in the recording. I'm sorry for the mistake. During the first part we watched this wiki page, the table of contents of the book and the slides that are given in the following), {{ :didattica:magistrale:com:ay_1819:01_introduction.pdf |Slides 1}}, {{ :didattica:magistrale:com:ay_1819:slides_2_03-10-2018.pdf |Slides 2}}, {{ :didattica:magistrale:com:ay_1819:cmp1819-03-10-2018.pdf |Notes}} 
  - 04/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=0d906ce8b809bb5383d9d6d66119820b|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=49422d95d9c3c85024fc5ab0fe43f35a|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:slides-04-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819-04-10-2018.pdf |Notes}}
  - 10/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=2d34a853a591d28ad2c96dd081d12fa5|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=f247a33f16a9432cb57d07c715350a1f|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-10-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-10-10-2018.pdf |Notes}}
  - 11/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=d8c152a7997d2305394386f9380d5cb9|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=8dc91feda440eb212493d75bc258de02|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-11-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819notes-11-10-2018.pdf |Notes}} - The last two pages of the notes contain the explanation of the last exercise that was left unsolved during the lecture
  - 17/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=f928517ec46d8894a43cbcbc205a12a0|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=56f8948c9b10901bbd329dfbe8fa774f|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-17-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819notes-17-10-2018.pdf |Notes}}
  - 18/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=1638fc25a8c8d5536eb1380869d19b97|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=10ad7de076ff868ebdb86ff4cce8bca0|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides18-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819notes-18-10-2018.pdf |Notes}}
  - 24/10/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=f43613c0ccc0a30530dc6c4ca961050e|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=b367d0e0b4c4d8de1f142640966321ef|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-24-10-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-24-10-2018.pdf |Notes}}
  - 07/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=96ba16be1b90dd480c5a36224c8af3a6|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=38aec9c9e056409a20b52abcffa56bad|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides07-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes07-11-2018.pdf |Notes}}, {{ :didattica:magistrale:com:ay_1819:cmp1819-07-11-2018-code.zip |Stub Code for a Recursive Descent Parser}}
  - 08/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=bcdcbc4acf87e45566ee7d513bf1b454|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=be9cbf3260fd96b7c2e38d8b5bbb82c3|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides08-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes08-11-2018.pdf |Notes}}
  - 14/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=64f398852ffc6f740f49d49bcf0d07a8|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=a219ef445026601dbfda65ff13286723|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpnotes14-11-2018.pdf |Notes}}
  - 15/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=1594d574c8c3f50b4eb91e14e022830f|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=2eb37a43fef10ccbf8de08b1ae483177|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides15-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes15-11-2018.pdf |Notes}}
  - 21/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=78356d8fc6945f806e32e5cb888e0c21|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=51825937603f2d590699e38284dd2958|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides21-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-21-11-2018.pdf |Notes}}
  - 22/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=9ab1d7568faad2173e0946864f8d1af4|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=b12c594bc21eb48a229823e8741a5a29|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-22-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-22-11-2018.pdf |Notes}}, [[https://www.sciencedirect.com/science/article/pii/S0019995865904262|Original Knuth paper on LR parsing]]
  - 28/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=78d30c3845083722843eee0090fa7a4d|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=425e3064a504ac970dfd804008d9344b|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-28-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-28-11-2018.pdf |Notes}}
  - 29/11/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=cf4778c873e975c7e165c42d63aead68|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=c3970797fbae278662bc8780457be028|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides29-11-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes29-11-2018.pdf |Notes}}
  - 05/12/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=1fa1e51924849086887663fc3020aec1|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=8e57a347d20697cca88ac7c646dcb183|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-05-12-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-05-12-2018.pdf |Notes}}
  - 06/12/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=e41e9696df92299d07eaa9ccebf6f176|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=014151db7ba37a5f6387db25a17ed077|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-06-12-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmpnotes-06-12-2018.pdf |Notes}}
  - 12/12/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=6992d38372527c07e14a566413e8e779|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=4a10eba50ee12edcb2e030847e7a7154|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides-12-12-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819notes-12-12-2018.pdf |Notes}}
  - 13/12/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=1d10283f96cae3b5e926e92d23369e26|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=41e0c2b31799580e483771a7d44eb1fc|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslides13-12-2018.pdf |Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp1819notes13-12-2018.pdf |Notes}}
  - 20/12/2018 - [[https://unicam.webex.com/unicam/ldr.php?RCID=f2b00670605d8b023f678446a2c23a02|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=2f2219d3f96317fb090438eb4c0833ee|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpslideslastsemanticanalysis.pdf |Last Slides Semantic Analysis}}, {{ :didattica:magistrale:com:ay_1819:antlrslidesdemo-20-12-2018.pdf |ANTLR4 Demo Slides}}, {{ :didattica:magistrale:com:ay_1819:antlr4_demo-20-12-2018.zip |ANTLR4 Demo Code}}, {{ :didattica:magistrale:com:ay_1819:antlrslidestour-20-12-2018.pdf |ANTLR4 Tour Slides}}, {{ :didattica:magistrale:com:ay_1819:cmp-20-12-2018-antlr4toureclipseproject.zip |ANTLR4 Tour Code}}
  - 17/01/2019 (Last Lecture) - [[https://unicam.webex.com/unicam/ldr.php?RCID=367d63b53261d6d6b2f47a3f52ba645f|Watch the Lecture]], [[https://unicam.webex.com/unicam/lsr.php?RCID=c2b71b314b9b7bd5557726e29feee2b0|Download the Lecture]], {{ :didattica:magistrale:com:ay_1819:cmpnotes-17-01-2019.pdf |Notes}}
 
**Exercise Sessions with Solutions**
Lexical Analysis:
  - {{ :didattica:magistrale:flc:ay_1819:lexical_analysis_exercise_session_i.pdf |Lexical Analysis Exercise Session I}}
  - {{ :didattica:magistrale:flc:ay_1819:lexical_analysis_exercises_3-4-5.pdf |Lexical Analysis Exercises 3-4-5}}
Syntax Analysis:
  - {{ :didattica:magistrale:flc:ay_1819:syntax_analysis_exercise_session_i.pdf |Syntax Analysis Exercise Session I}}
  - {{ :didattica:magistrale:flc:ay_1819:syntax_analysis_exercise_session_ii.pdf |Syntax Analysis Exercise Session II}}
  - {{ :didattica:magistrale:flc:ay_1819:syntaxanalysis_exercise1.pdf |Syntax Analysis Exercise 1}}
Semantic Analysis:
  - {{ :didattica:magistrale:flc:ay_1819:semanticanalysis_exercise1.pdf |Semantic Analysis Exercise 1}}
  - {{ :didattica:magistrale:flc:ay_1819:semanticanalysis_exercise3.pdf |Semantic Analysis Exercise 3}}
  - {{ :didattica:magistrale:flc:ay_1819:semanticanalysis_exercise5.pdf |Semantic Analysis Exercise 5}}
  - {{ :didattica:magistrale:flc:ay_1819:semanticanalysis_exercise9.pdf |Semantic Analysis Exercise 9}}
**Sample Past Written Tests with Solutions**
  - {{:didattica:magistrale:flc:ay_1516:20160614_solution.pdf|June 14th, 2016}}
  - {{:didattica:magistrale:flc:ay_1516:20160705_solution.pdf|July 5th, 2016}}
  - {{:didattica:magistrale:flc:ay_1718:flc1718appello2.pdf| Text July 12th, 2018}}, {{:didattica:magistrale:flc:ay_1718:flc1718app2solution.pdf| Solution July 12th, 2018}}
**Textbooks**
  * [ALSU] Alfred V. Aho, Monica S. Lam, Ravi Sethi and Jeffrey D. Ullman, [[http://dragonbook.stanford.edu/|Compilers -- Principles, Techniques and Tools]], 2nd Edition,  Addison-Wesley, 2007.
  * [TP] Terence Parr [[https://pragprog.com/book/tpantlr2/the-definitive-antlr-4-reference|The Definitive ANTLR4 Reference]], The Pragmatic Programmers, 2012.
----
===== Project =====
**Project to be sent the day of the Partial Exam "CMP1819 Sess. X - Project" in each session X:**
  - 17/12/2018 - {{ :didattica:magistrale:com:ay_1819:cmp1819projecttrack.zip |Track of the project}}, read carefully the submission guidelines. **Errata Corrige** of 18/01/2019, please download  this {{ :didattica:magistrale:com:ay_1819:cmp1819projecttrack-errata_corrige.zip |archive}} and read the file Errata Corrige.txt
----
===== Exams =====
**Exam Dates A.Y. 2018/2019 (Written Test Days)** - For each session, projects can be sent by the day before the written test
  - 31/01/2019 - 3pm 06/02/2019 - 3pm - Room LA1, {{ :didattica:magistrale:com:ay_1819:flc1819appello1.pdf |Text}}, {{ :didattica:magistrale:com:ay_1819:flc1819appello1_solution_full.pdf |Text with Solution (corrected on 20/02/2019 - there was an error in the solution of exercise 2)}}
  - 21/02/2019 - 3pm - Room AB1, {{ :didattica:magistrale:com:ay_1819:flc1819appello2.pdf |Text}}, {{ :didattica:magistrale:com:ay_1819:flc1819appello2_solution_full.pdf |Text with Solution}}
  - 12/06/2019 - 3pm - Room AA1
  - 26/06/2019 - 3pm - Room AA1
  - 16/07/2019 - 3pm - Room TBD 23/07/2019 - 3pm - Room AA1, {{ :didattica:magistrale:com:ay_1819:flc1819appello4.pdf |Text}}, {{ :didattica:magistrale:com:ay_1819:flc1819appello4solutionwithnotes.pdf |Text with Solution}}
  - 11/09/2019 - 3pm - Room AB2, please register to the Partial Exam "CMP1819 Sess. VI - Written Test" on ESSE3 before 06/09/2019
  - 25/09/2019 - 3pm - Room AB2, please register to the Partial Exam "CMP1819 Sess. VII - Written Test" on ESSE3 before 20/09/2019
  - 25/03/2020 - 3pm - Room TBD, please register to the Partial Exam "CMP1819 Sess. VIII - Written Test" on ESSE3 before 20/03/2020
For registration, please consult the [[https://didattica.unicam.it|ESSE3 Portal]] after login.
**Exam rules**
The exam consists of a written test, containing open-answer questions, together with one project, realised with the ANTLR tool (see section "Projects" above). The Written Test and the Project are two independent Partial Exams (see the exam sessions in the ESSE3 career system) and can be passed in different exam sessions. The final grade, which is the average of the grades of the two Partial Exams, can be obtained and registered only if both the Partial Exams have been passed with a grade of at least 18/30.  
**Registration for the written tests** must be done using the Student Career System ESSE3 [[https://didattica.unicam.it|here]]. Please note that the registration **deadline** is usually **3 working days before** the written test date. This course is not mandatory for the BSc and for any MSc curriculum, therefore BSc students or MSc students will not be able to register for the written test until they communicate to the Secretary Office (Tiziana Jajani c/o Student Secretary Office -  [[http://www.unicam.it/studente/segreterie-studenti|Opening Hours]]) their choice to attend to this course, code [ST1184] COMPILERS. During the exercise sessions throughout the course samples of the written test questions will be presented with solutions. During the written test students can consult a hand-written A4 paper of their production for reference.
**Instructions for Sending Projects**
Students must create a folder in Google Drive, using the Google account associated to their email name.surname@studenti.unicam.it 
The folder must contain all the files relative to the project and a written report, in English, which describes all the phases of the developing of the project. The use of screenshots is encouraged to show, within the report, the runs and the results of the project. 
The folder must be named 
CMP1819-Project-N-APP-X-Surname-Name
where N is the number of the realised project (according to the section "Projects" above) and X is the number of the exam session (Appello) as specified for each date of the written test above. 
The folder must be shared (using Google Drive facilities) with luca.tesei@unicam.it and andrea.polini@unicam.it by 11.59pm of the day before the written test scheduled for the selected session X.
Students that send the project must also register to the Partial Exam "CMP1819 Sess. XXX - Project" in ESSE3, specified for each exam session. 
** Exam Results **
  * The results will be communicated through this site or by email (depending on the number of students). 
  * Contextually to the communication of the results, students will be invited to accept or reject the evaluation. 
  * A positive evaluation (>=18/30) of each Partial Exam (Written Test and Project) remains valid for **one year** or **until the student retries** the Partial Exam.
  * If both grades (Written Test and Project) are accepted, the final grade will be registered in ESSE3.