UPM / IMDEA Software Institute Specialization Track in Software Development through Rigorous Methods (2017-2018)
Table of Contents
Note: this course is taught at the the IMDEA Software Institute (in the Montegancedo Campus, 500 m. from the CS School). Please get in touch with the coordinator or one of the instructors for more details regarding the exact meeting place and possible schedule changes.
This course has specific requirements. If you are not a student affiliated to the IMDEA Software Institute, please follow these instructions. If you do not follow them, you may be asked to register in some other course.
Foundations for Programming Languages
Coordinator(s)
Instructor(s)
Length
4 credits (ECTS)
Prerequisites
Course web page (if any)
Not yet available.
Summary and objectives
This course provides the formal background needed to reason about software and programming languages in a precise and mathematically sound way.
Fundamental conceps underlying the design, definition and execution mechanisms of programming languages are covered, including recursion, syntax, various forms of semantics and type systems.
Alongside the theoretical contents, the course may include small programming assignments to gain a more instrumental level of the ideas mentioned above.
Topics
- Introduction
- Overview, motivation, and challenges for SW technologies
- Review of background: programming, logic, mathematical structures…
- Syntax
- Abstract and concrete syntax definitions
- Recursion and induction
- Lambda-calculi
- Abstract and concrete syntax definitions
- The untyped lambda-calculus
- Simply-typed lambda-calculus
- Semantics
- Operational semantics
- Denotational semantics
- Type systems
- Natural deduction
- The Curry-Howard isomorphism
- Polymorphism
- Algebraic/recursive types
- Reference types; Monads; Effects
- Subtyping
Evaluation
The final grade will be obtained from:
- A suite of short, individual practical/theoretical exercises periodically proposed which will be worth 50% of the final grade.
- The remaining 50% will come from from a written exam paper.
Exercises for each unit will have the same relative weight for the overall grade, although individual exercises in a given unit can have different weights.
Recommended reading
Foundations for Programming Languages. John C. Mitchell. The MITPress, 1996.
Back to the initial page
Go to the IMDEA Software Institute page