1 / 23

Prolog Programming Essentials: List Length, Control, Trees

Explore Prolog programming with list length calculations, control flow, and binary search trees. Learn key concepts such as unification and search tree manipulation.

aloretta
Download Presentation

Prolog Programming Essentials: List Length, Control, Trees

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. CS 403 - Programming Languages Class 21 November 9, 2000

  2. Today’s Agenda • Finish Chapter 15 • Assignment: • Read chapter 15 for today • Announcement: • Programming assignment.

  3. Objectives • Introduction to using Prolog

  4. Length of Lists I • The Problem: Define a relation llength(L,N) to mean that the length of the list L is N. • The Program: • llength([],0). • llength([X|Z],N):- llength(Z,M), N is M + 1.

  5. Watch it work: • ?- [length]. • ?- llength([a,b,c,d],M). • M=4

  6. Length of Lists II • The Program: • llength([],0). • llength([X|Z],N) :- N is M + 1, llength(Z,M).

  7. Watch it work: • ?- [length2]. • ?- llength([a,b,c,d],M). • evaluation_error: [goal(_1629 is _1805+1),argument_index(2)]

  8. Control in Prolog I • How Prolog tries to solve a query like: • <query1>, <query2>, .... , <queryN> • This is the control side of the equation: • Algorithm=Logic+Control • Step 1: Find Things that solve <query1>, if none then fail else goto Step 2 • Step 2: Do the things found from the previous step allow more things to be found that solve <query2>? If not then go back to step1 else goto step 3.......

  9. Control in Prolog I • Prolog tries to solve the clauses from left to right If there is a database file around it will use it in a similarly sequential fashion. • 1. Goal Order: Solve goals from left to right. • 2. Rule Order: Select the first applicable rule, where first refers to their order of appearance in the program/file/database

  10. Control in Prolog II • The actual search algorithm is: • 1. start with a query as the current goal. • 2. WHILE the current goal is non-empty • DO choose the leftmost subgoal ; • IF a rule applies to the subgoal • THEN select the first applicable rule; form a new current goal; • ELSE backtrack; • SUCCEED

  11. Control in Prolog II • Note 1: Thus the order of the queries is of paramount importance . • Note 2: The general paradigm in Prolog is Guess then Verify: Queries with the fewest solutions should come first, followed by those that filter or verify these few solutions

  12. Binary Search Trees I • An example of user defined data structures. • The Problem: Recall that a binary search tree (with integer labels) is either : 1. the empty tree empty,or 2. a node labeled with an integer N, that has a left subtree and a right subtree, each of which is a binary search tree such that the nodes in the left subtree are labeled by integers strictly smaller than N, while those in the right subtree are strictly greater than N.

  13. Data Types in Prolog • The primitive data types in prolog can be combined via structures,to form complex datatypes: • <structure>::= <functor>(<arg1>,<arg2>,...) • Example In the case of binary search trees we have: • <bstree> ::= empty • | node(<number>, <bstree>, <bstree>) • node(15,node(2,node(0,empty,empty), • node(10,node(9,node(3,empty,empty), • empty), • node(12,empty,empty))), • node(16,empty,node(19,empty,empty))) • Draw this tree

  14. Binary Search Trees II • The Problem: Define a unary predicate isbstree which is true only of those trees that are binary search trees . • The Program isbstree(empty). isbstree(node(N,L,R)):- number(N),isbstree(L),isbstree(R), smaller(N,R),bigger(N,L). smaller(N,empty). smaller(N, node(M,L,R)) :- N < M, smaller(N,L), smaller(N,R). bigger(N, empty). bigger(N, node(M,L,R)) :- N > M, bigger(N,L), bigger(N,R).

  15. Watch it work: • ?- [btree]. • ?- isbstree(node(9,node(3,empty,empty),empty)). • true ? • yes

  16. Binary Search Trees III • The Problem: Define a relation which tells whether a particular number is in a binary search tree . • mymember(N,T) should be true if the number N is in the tree T. • Now you try it • The Program mymember(K,node(K,_,_)). mymember(K,node(N,S,_)) :- K < N,mymember(K,S). mymember(K,node(N,_,T)) :- K > N,mymember(K,T).

  17. Watch it work: • ?- [btree]. • ?- [mymember]. • ?- mymember(3, node(10,node(9,node(3,empty,empty),empty), node(12,empty,empty))). • true ? • yes

  18. Unification • Unification is a more general form of pattern matching. In that pattern variables can appear in both the pattern and the target. • The following summarizes how unification works: 1. a variable and any term unify 2. two atomic terms unify only if they are identical 3. two complex terms unify if they have the same functor and their arguments unify .

  19. Prolog Search Trees Summary • 1. Goal Order affects solutions • 2. Rule Order affects Solutions • 3. Gaps in Goals can creep in • 4. More advanced Prolog programming manipulates the searching

  20. Sublists (Goal Order) • Two definitions of S being a sublist of Z use: myappend([], Y, Y). myappend([H|X], Y, [H|Z]) :- myappend(X,Y,Z). & myprefix(X,Z) :- myappend(X,Y,Z). mysuffix(Y,Z) :- myappend(X,Y,Z). Version 1 sublist1(S,Z) :- myprefix(X,Z), mysuffix(S,X). Version 2 sublist2(S,Z) :- mysuffix(S,X), myprefix(X,Z). Version 3 sublist3(S,Z) :- mysuffix(Y,Z), myprefix(S,Y).

  21. Watch them work: | ?- [sublist]. consulting....sublist.pl yes | ?- sublist1([e], [a,b,c]). no | ?- sublist2([e], [a,b,c]). Fatal Error: global stack overflow …

  22. Version 1 • So what’s happening? If we ask the question: sublist1([e], [a,b,c]). this becomes prefix(X,[a,b,c]), suffix([e],X). and using the guess-query idea we see that the first goal will generate four guesses: [] [a] [a,b] [a,b,c] none of which pass the verify goal, so we fail.

  23. Version 2 • On the other hand, if we ask the question: • sublist2([e], [a,b,c]) • this becomes • suffix([e],X),prefix(X,[a,b,c]). • using the guess-query idea note: • Goal will generate an infinite number of guesses. • [e] [_,e] [_,_,e] [_,_,_,e] [_,_,_,_,e] [_,_,_,_,_,e] • .... • None of which pass the verify goal, so we never terminate

More Related