Logic Programming

ID : 
ΥΣ05
Semester : 
6
Credit hours (lecture): 
3
Credit hours (discussion): 
1
Track: 
Computer Systems and Applications

Procedural and declarative programming. Logic programming as an instance of declarative programming. The Prolog programming language. Syntax of programs. Lists. Operators. Arithmetic. Control of backtracking. Negation in Prolog. Built-in predicates. Handling of data structures. Applications of Prolog in search problems, symbolic processing, natural language understanding and meta-programming. Expert systems and logic programming. Theory of logic programming. Interpretations and models. Model theoretic semantics. Fixpoint semantics. Unification. SLD-resolution. Operational semantics. Constraint logic programming. Implementation techniques of logic programming systems. Parallel logic programming. Logic programming for knowledge representation. Knowledge representation – methodologies and implementations using Prolog. Knowledge-based systems – the expert systems case. Deductive databases – the Datalog case. Logic programming and theWorld WideWeb.