KEMBAR78
Logic Programming in Prolog: Par (Lloyd, James) - Par (Lloyd, Janet) . | PDF | Mathematics Of Computing | Computer Programming
0% found this document useful (0 votes)
79 views3 pages

Logic Programming in Prolog: Par (Lloyd, James) - Par (Lloyd, Janet) .

Prolog is a declarative logic programming language where programs consist of facts and rules that define relationships. Facts are statements relating constants, while rules relate predicates and use variables. A Prolog program uses a query to test if facts and rules can infer a relationship. For example, a knowledge base about family trees can be queried to deduce grandparent relationships from facts stating parents.

Uploaded by

wajahat
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
79 views3 pages

Logic Programming in Prolog: Par (Lloyd, James) - Par (Lloyd, Janet) .

Prolog is a declarative logic programming language where programs consist of facts and rules that define relationships. Facts are statements relating constants, while rules relate predicates and use variables. A Prolog program uses a query to test if facts and rules can infer a relationship. For example, a knowledge base about family trees can be queried to deduce grandparent relationships from facts stating parents.

Uploaded by

wajahat
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 3

Logic Programming In Prolog

Prolog is referred to as a declarative language because all program statements are definitional. In
particular, a Prolog program consists of facts and rules which serve to define relations (in the
mathematical sense) on sets of values. The imperative (computational) component of Prolog is its
execution engine based on unification and resolution, a mechanism for recursively extracting sets of
data values implicit in the facts and rules of a program.

Facts and Rules


Everything in Prolog is defined in terms of two constructs: the fact and the rule.
 A fact is a Prolog statement consisting simply of an identifier followed by an n-tuple of constants.
Example:
Here is a set of facts describing parental relationships.
par(lloyd, james). par(lloyd, janet).

*Note that facts always consist of constants.

 The predicate is interpreted as the name of a (mathematical) relation and the fact states that the
specified n-tuple is in the relation.

Example:
grand(X, Y) means that X is a grandparent of Y.

*Note that predicate contains variables


** Variables are written in capital

 Rule: Rules provide room for abstraction and inference. These are of the form “if ‘a’ ”
“then ‘b’ “, The if part of the rule is called “antecedent” and the then part of the rule is called
“consequent”
In prolog “ A :- B, C “ is a rule, read as, “A is true if B is true and C is true.”
Example:
grand(X, Z) :- par(Y, Z), par(X, Y).
This rule states that X is the grand parent of Z if, Y is the parent of Z and X is the parent of Y.

*Note that in rules “ , ” means AND . “ ;” means OR


Querying:
We can put facts into a computer. So what can we do with them? Well, we want to reason about facts
and conclude new facts--what's called inference.
 To get some output we can use a variable in the query (non-ground queires).
 And to let prolog answer us, we just state a fact and prolog answers whether it’s true or not
(ground queries).
Example:
Consider you have created the following Knowledge base containing the facts and rules :

par(lloyd, james).
par(lloyd, janet).
par(ruth, james).
par(ruth, janet).
par(emma, lloyd).
par(katherine, ruth).
par(adolph, lloyd).
par(edgar, ruth).

grand(X, Z) :- par(Y, Z), par(X, Y).

Now a possible query is ?- par(ruth,C)


Read as Find a C such that Ruth is the parent of C (or) Whose parent is Ruth.
Upon executing , Prolog will return
C=james
Type a semicolon at this point and press enter to see alternatives, more results for the query.
 Queries can be Multi directional. i.e. par(X,emma) and par(emma,X)
 Queries Can be multiconditional i.e.
Par(emma,X), garand(ruth).
 This query will only execute if child of emma is grandparent of ruth.
 These are also called compound queries.

Working:
?- in prolog interface means query mode.
Write facts, predicates and rules in a text file and save the file with extension “p” or “pl”
To open a file, Click File-> consult and select the file, on prolog interface presses enter.
Prolog will return to query mode(?-).
Now you can practice different type of queries here.
Full Example:
IF family is albatross and color is white
THEN bird is laysan_albatross
In Prolog the same rule is:
bird(laysan_albatross) :- family(albatross), color(white).
The following rules distinguish between two types of albatross and swan.
bird(laysan_albatross):- family(albatross), color(white).
bird(black_footed_albatross):- family(albatross), color(dark).
bird(whistling_swan) :- family(swan), voice(muffled_musical_whistle).
bird(trumpeter_swan) :- family(swan), voice(loud_trumpeting).
In order for these rules to succeed in distinguishing the two birds, we would have to store facts about a
particular bird that needed identification in the program. For example if we added the following facts to
the program:
family(albatross).
color(dark).
then the following query could be used to identify the bird:
?- bird(X).
X = black_footed_albatross

Similarly build a knowledge base with more facts and practice different Querries.

You might also like