Content
The course provides an introduction to functional programming, covering both, practical examples using OCaml (a functional language) and theoretical background.
Lecture notes can be downloaded within the university network and are also available at Studia. Studia also sells the last year's edition, which you can use, the current one only has some small mistakes corrected. Please note the new location of Studia (Zeichensaal T21b, Untergeschoss).
Schedule
week | date | topics | slides | sources | exercises | history |
---|---|---|---|---|---|---|
1 | 03.10. | historical overview, OCaml introduction, first steps | txt | |||
2 | 10.10. | lists, polymorphism, higher-order functions | txt | |||
3 | 17.10. | modules, strings | tgz | txt | ||
4 | 24.10. | user-defined types, trees | tgz | txt | ||
5 | 31.10. | introduction to lambda calculus | ||||
6 | 6.11. | lambda calculus, evaluation strategies | txt | |||
7 | 14.11. | induction, reasoning about functional programs | ||||
8 | 21.11. | efficiency, tail-recursion | ||||
9 | 28.11. | combinator parsing / functional parsers | tgz | txt | ||
10 | 5.12. | types, type checking, type inference | ||||
11 | 12.12. | implementing type inference | tgz | |||
12 | 9.01. | lazyness | tgz | txt | ||
13 | 16.01. | dependent types | ||||
14 | 23.01. | monads, efficiency | ||||
- | 30.01. | 8:00-10:00 first exam HS-D | ||||
- | 2.03. | 14:00-16:00 second exam HSB-9 | ||||
- | 25.09. | 14:00-16:00 third exam HSB-9 |