Courses: INF122 Functional Programming - Autumn 2017
Credits
10.0Teaching semester
Autumn.
Objectives and Content
A functional program consists of definitions of functions and its effect is determined by the input-output behaviour of these functions. Functional programming is the central example of the declarative paradigm, where program, in addition to its operational interpretation, has also a dual one: as a formula with static meaning independent from the transitions between program states. Execution of a program corresponds then to this declarative interpretation and this facilitates development and maintenance of correct software. The course introduces basic concepts from the functional paradigm through programming in a functional language (e.g., Haskell).
Learning Outcomes
After the course, the students shall know how to program with functions, understand and use recursion, algebraic data types (such as lists and trees), higher order functions and polymorphic functions.
Required Previous Knowledge
Recommended Previous Knowledge
INF100, MNF130
Compulsory Assignments and Attendance
Compulsory exercises.
Grading Scale
The grading scale used is A to F. Grade A is the highest passing grade in the grading scale, grade F is a fail.
Subject Overlap
INF121: 5 credits, INF121A: 5 credits