Table of Contents

Functional and Logic Programming — ae4b33flp

( home | lectures | tutorials | homework )

Summary

This course introduces students into the techniques of functional programming in the LISP (or more precisely SCHEME) and HASKELL language and logic programming in the PROLOG language. Both languages are declarative in that the programmer symbolically describes the problem to be solved, rather than enumerating the exact sequence of actions to be taken. In PROLOG, one describes the problem by specifying properties of objects and relations thereamong through logic formulas. In LISP, the problem description takes the form of function definitions. Both languages have found significant applications in artificial intelligence fields, such as agent systems or symbolic machine learning. Motivating tasks from these domains will be used throughout the course.

Credit requirements

The tutorials consist of two halves (Scheme + Prolog). Each is evaluated separately according to following rules:

The (normal) points obtained during the semester are transferred to the exam.

Assignments

Scheme

Exam

Students who receive the credit (based on points from the tutorials) are allowed to take the exam. The written exam has a theoretical part and a practical part (programming). Additional points can be obtained during the oral exam.

For the exam a maximum of 50 points can be awarded. A minimum of 12.5 points must be achieved both in the functional and logical part for a passing grade.

The final grade is assigned according to the sum of tutorials and exam points.

ECTS grade Pass Fail
A B C D E F
Points 100-90 89-80 79-70 69-60 59-50 49-0

Literature

Teachers

Functional programming
Lecturer Tutorial instructors
Jiří Vyskočil jjakubuv.jpg
Jiří Vyskočil Jan Jakubův
Logic programming
Lecturer Tutorial instructors
Filip Železný Gustav Šourek Radomír Černoch
Filip Železný Gustav Šourek Radomír Černoch