Denotational Semantics is about assigning a mathematical meaning to syntax (in particular, that of programming languages) which is, in some sense, independent of how the syntax is presented, or what computational rules it may obey (which are properly the subject matter of Operational Semantics).
Domain Theory is the mathematics of the objects, sets-with-structure, and mappings between them, which serve as a vehicle for denotational semantics.
Fresh up material for those who haven't followed Semantiek and Correctness or Semantics and Rewriting or have forgotten some of that:
Further reading material:
The course is divided roughly into 3 parts:
There is a written exam, which is "open book", so you can take the course notes and your own notes to the exam. Apart from that there is a small assignment, see below.
The final grade is 3/4 of your written exam grade + 1/4 of your assignment grade.
| Year-week | Order | Date | Material | Exercises, discussed on: |
| 36 | 1 | 2/9 | Slides and Section 1.1 of DENS | exercises, 10/9 |
| 37 | 2 | 9/9 | Section 1.2 of DENS and recap of Operational Semantics of "While" | exercises, 17/9 |
| 38 | 3 | 16/9 | Sections 2.1, 2.3, 3.1 of DENS (skip 2.2, slide 27 and 2.4) | exercises, 24/9 |
| 39 | 4 | 23/9 | Sections 2.2, 2.4, 3.2 of DENS | exercises, 1/10 |
| 40 | 5 | 30/9 | Sections 3.3, 4.1, 4.2 of DENS | exercises, 8/10 |
| 41 | 6 | 7/10 | Sections 4.3, 5.1, 5.2, 5.3 of DENS | exercises, 15/10 |
| 42 | 7 | 14/10 in HG00.310 | Sections 5.4, 5.5, 5.6 of DENS + presentation of the assignment | exercises, 5/11 |
| 43 | No lecture, autumn break | |||
| 44 | No lecture, autumn break | |||
| 45 | 8 | 4/11 | Chapter 6 of DENS | exercises, 12/11 |
| 46 | 9 | 11/11 | Chapter 7 of DENS | exercises, 19/11 |
| 47 | 10 | 18/11 | Chapter 8 of DENS and Notes on dI domains first part | exercises 1--5, 26/11 |
| 48 | 11 | 25/11 | Notes on dI domains continued | exercises 6--11, 3/12 |
| 49 | 12 | 2/12 | Short lambda calculus recap and Models of untyped lambda calculus, Section 1 and Section 2.1 | exercises, 10/12 |
| (If lambda calculus is new: read the Introduction to Lambda Calculus and try ex. 2.5 -- 2.10. For a lambda calculus "fresh up": read the first 4 pages of Models of untyped lambda calculus and do Exercises 1.7, 1.8, 1.9.) | ||||
| 50 | 13 | 9/12 | Models of untyped lambda calculus, Section 2.2, Section 2.3 and Example 3.1 | exercises, 17/12 |
| 51 | 14 | 16/12 | Models of untyped lambda calculus, Section 3 | exercises |
| 3 | 16/1, 12:45-15:45 | EXAM |
The written exam is "open book", so you can take the course notes and your own notes to the exam. Dates:
The deadline for the assignment
is January 20. The resit deadline for the assignment
is April 8.
In the assignment, you are requested to apply your knowledge on
denotational semantics to a concrete programming language or
programming concept (of your own choice). This should result in a
short note (max 10 pages). See the
assignment explanation. Your work should be sent to the teacher via
mail, as a pdf file. You can do the assignment in couples; please
write clearly on the title page the names and student numbers of the
authors of the assignment.