Functional Programming: 20192020
Lecturer  
Degrees  Preliminary Examinations — Computer Science and Philosophy Preliminary Examinations — Computer Science 
Term  Michaelmas Term 2019 (16 lectures) 
Overview
MSc students will be assessed by invigilated exam lasting 3 hours in week 0 of HT.
This is a first course in programming. It makes use of a programming language called Haskell, in which programs can be viewed as mathematical functions. This makes the language very powerful, so that we can easily construct programs that would be difficult or very large in other languages.
An important theme of the course is how to apply mathematical reasoning to programs, so as to prove that a program performs its task correctly, or to derive it by algebraic manipulation from a simpler but less efficient program for the same problem.
The course provides handson experience of programming through two lab exercises: the first one aims to make you acquainted with the mechanics of writing Haskell programs, and the second one tackles a more challenging programming task.
Learning outcomes
At the end of the course the student will be able to:
 Write programs in a functional style;
 Reason formally about functional programs;
 Use polymorphism and higherorder functions;
 Reason about the time and space complexity of programs.
Synopsis
 Programming with a functional notation: sessions and scripts, expressions and values. Evaluation of expressions. Reduction strategies: innermost vs outermost. Functional application and currying. Functional composition.
 Types and strongtyping. Basic types: Booleans and truth values. Simple programs involving pattern matching. Polymorphism and type classes. More types: characters, strings, tuples. Type synonyms.
 Lists and their operations; list comprehensions. The functions map, foldl, foldr, concat and filter. Many small examples illustrating the use of these functions in a compositional style of programming.
 Recursion and induction. The algebraic properties of list functions and their proof by equational reasoning. Simple manipulation of programs to achieve efficiency.
 Infinite lists and their applications: Pascal's triangle, digits of a number, sieve of Eratosthenes. Infinite lists as limits. Proving properties of infinite lists: induction, take lemma.
 Nonlinear data structures. Binary trees and the relationship between size and depth. Binary search trees for representing sets. Insertion and searching in a binary search tree.
 Time complexity. Asymptotic notation. Advice on writing efficient programs; use of accumulating parameters.
 Arithmetic expressions: representing, evaluating and manipulating arithmetic expressions. Building a simple parser.
 Monads
Syllabus
Principles of functional programming: expressions, evaluations, functions, and types. Type definitions and builtin types: numbers, characters, strings and lists. Basic operations on lists, including map, fold and filter, together with their algebraic properties. Recursive definitions and structural induction. Simple program calculation. Infinite lists and their uses. Further data structures: binary trees, general trees. Use of trees for representing sets and symbolic data. Normal order reduction and lazy evaluation. Simple cost models for functional programs; time and space complexity.Reading list
Course text:
Either of
 Richard Bird, Introduction to Functional Programming using Haskell, second edition, PrenticeHall International, 1998.
 Graham Hutton, Programming in Haskell (2nd edition), Cambridge University Press, 2016.
Additional Reading:
 Richard Bird, Thinking Functionally With Haskell, Cambridge University Press, October 2014.
 Bryan O'Sullivan, Don Stewart, and John Goerzen, Real World Haskell, O'Reilly Media, 2008.
 Miran Lipovača, Learn You a Haskell for Great Good! A Beginner's Guide, No Starch Press, 2011.
 Simon Thompson, Haskell: The Craft of Functional Programming, AddisonWesley, 1996.
 Paul Hudak, The Haskell School of Expression, Cambridge University Press, 2000.
 Paul Chiusano and Rúnar Bjarnason, Functional Programming in Scala. Manning Publications Co., 2014.

The Haskell standard Prelude
Taking our courses
This form is not to be used by students studying for a degree in the Department of Computer Science, or for Visiting Students who are registered for Computer Science courses
Other matriculated University of Oxford students who are interested in taking this, or other, courses in the Department of Computer Science, must complete this online form by 17.00 on Friday of 0th week of term in which the course is taught. Late requests, and requests sent by email, will not be considered. All requests must be approved by the relevant Computer Science departmental committee and can only be submitted using this form.