Detail předmětu
Funkcionální a logické programování
FIT-FLPAk. rok: 2020/2021
Praktické aplikace a širší úvod do lambda kalkulu a predikátové logiky v prostředí funkcionálních a logických programovacích jazyků. V rámci funkcionálního programování jsou diskutovány abstraktní datové typy, použití rekurze a indukce, práce se seznamy a nekonečnými datovými strukturami v jazyce Haskell. V rámci logických jazyků základy programování v jazyce Prolog (operátor řezu, prohledávání stavového prostoru, změna databáze), Goedel, CLP a principy jejich implementace.
Jazyk výuky
Počet kreditů
Garant předmětu
Zajišťuje ústav
Výsledky učení předmětu
Užití a zvládnutí rekurze pro algoritmizaci.
Prerekvizity
Způsob a kritéria hodnocení
- Půlsemestrální zkouška, u které neexistuje náhradní, či opravný termín.
- Vypracování 2 projektů v průběhu semestru a jejich odevzdání ve stanoveném termínu.
Podmínky zápočtu:
Student musí během semestru získat alespoň 50% bodů z možného maxima, tj. 20 bodů ze 40.
Pokud bude odhaleno plagiátorství nebo nedovolená spolupráce na projektech, či u půlsemestrální zkoušky, zápočet nebude udělen a dále bude zváženo zahájení disciplinárního řízení.
Učební cíle
Vymezení kontrolované výuky a způsob jejího provádění a formy nahrazování zameškané výuky
- Půlsemestrální zkouška - písemná, formou otázek a úkolů, neexistuje náhradní/opravný termín - 20 bodů.
- Vypracování projektů - 2 projekty, jeden ve funkcionálním a druhý v logickém programovacím jazyce - jednoduché programy, dle zadání - 20 bodů celkem.
- Závěrečná zkouška - písemná, formou otázek a úkolů, 2 opravné termíny (60 bodů - pro získání bodů ze zkoušky je nutné zkoušku vypracovat tak, aby byla hodnocena nejméně 25 body, v opačném případě bude zkouška hodnocena 0 body).
Doporučená literatura
Jones, S.P.: Haskell 98 Language and Libraries, Cambridge University Press, 2003, p. 272, ISBN 0521826144
Lecture materials (slides, demos, etc.)
Lipovača, M.: Learn You a Haskell for Great Good!, No Starch Press, 2011, ISBN-13: 978-1-59327-283-8
Nilsson, U., Maluszynski, J.: Logic, Programming and Prolog (2ed), John Wiley & Sons Ltd., 1995
Thompson, S.: Haskell, The Craft of Functional Programming, ADDISON-WESLEY, 1999, ISBN 0-201-34275-8
Zařazení předmětu ve studijních plánech
- Program IT-MGR-2 magisterský navazující
obor MGM , 0 ročník, letní semestr, povinně volitelný
obor MBI , 0 ročník, letní semestr, volitelný
obor MBS , 1 ročník, letní semestr, povinný
obor MIN , 1 ročník, letní semestr, povinný
obor MIS , 1 ročník, letní semestr, povinný
obor MMI , 1 ročník, letní semestr, povinný
obor MMM , 0 ročník, letní semestr, povinný
obor MPV , 0 ročník, letní semestr, povinně volitelný
obor MSK , 0 ročník, letní semestr, volitelný - Program MITAI magisterský navazující
specializace NISY , 1 ročník, letní semestr, povinný
specializace NADE , 1 ročník, letní semestr, povinný
specializace NBIO , 1 ročník, letní semestr, povinný
specializace NCPS , 1 ročník, letní semestr, povinný
specializace NEMB , 0 ročník, letní semestr, povinný
specializace NHPC , 1 ročník, letní semestr, povinný
specializace NGRI , 1 ročník, letní semestr, povinný
specializace NIDE , 1 ročník, letní semestr, povinný
specializace NISD , 1 ročník, letní semestr, povinný
specializace NMAL , 1 ročník, letní semestr, povinný
specializace NMAT , 1 ročník, letní semestr, povinný
specializace NNET , 1 ročník, letní semestr, povinný
specializace NSEC , 1 ročník, letní semestr, povinný
specializace NSEN , 1 ročník, letní semestr, povinný
specializace NSPE , 1 ročník, letní semestr, povinný
specializace NVER , 1 ročník, letní semestr, povinný
specializace NVIZ , 1 ročník, letní semestr, povinný
Typ (způsob) výuky
Přednáška
Vyučující / Lektor
Osnova
- Úvod do funkcionálního programování
- Lambda kalkul
- Programovací jazyk Haskell, úvod, práce se seznamy
- Uživatelské datové typy, typové třídy a pole v jazyce Haskell
- Vstupy/výstupy v jazyce Haskell - typové třídy IO a Monad
- Dokazování ve funkcionálním programování
- Denotační sémantika, implementace funkcionálních jazyků
- Prolog, úvod
- Seznamy, operátor řezu a řazení v jazyce Prolog
- Datové struktury, řetězce, operátory - rozšíření v jazyce SWI Prolog
- Stavový prostor, práce s klauzulemi a analýza jazyků v jazyce Prolog
- Goedel - logický programovací jazyk nevyužívající Hornovy klauzule
- Implementace logických jazyků, CLP, shrnutí, diskuse
Cvičení na počítači
Vyučující / Lektor
Osnova
- Haskell - základní rysy jazyka, rekurze, seznamy, částečná aplikace, funkce vyššího řádu (map, filter, foldX), ukázka práce s nekonečným seznamem, zkrácené vyhodnocování
- Haskell - datové typy, monády, vstup/výstup
- Haskell - demonstrační cvičení - konstrukce jednoduchého interpretru s pomocí knihovny Parsec
- Prolog - struktura programu, rekurze, seznamy
- Prolog - dynamické predikáty, pokročilejší příklad
- Prolog - náročnější příklady, testování instanciace proměnných, prohledávání stavového prostor
Projekt
Vyučující / Lektor
Osnova
- Jednoduchý program v jazyce Haskell (Hugs, GHC, GHCi).
- Jednoduchý program v jazyce Prolog/Gödel/CLP(R) (SWIPL, Gödel, CiaoProlog).