Professional Documents
Culture Documents
Logic in AI: (With Some Slides From Mausam, Stuart Russell, Dieter Fox, Henry Kautz )
Logic in AI: (With Some Slides From Mausam, Stuart Russell, Dieter Fox, Henry Kautz )
Logic in AI: (With Some Slides From Mausam, Stuart Russell, Dieter Fox, Henry Kautz )
Chapter 7
Dan Weld
(With some slides from Mausam, Stuart
Russell, Dieter Fox, Henry Kautz…)
Knowledge Representation
• Typically based on
– Logic
– Probability
– Logic and Probability
Some KR Languages
• Propositional Logic
• Predicate Calculus
• Frame Systems
• Rules with Certainty Factors
• Bayesian Belief Networks
• Influence Diagrams
• Semantic Networks
• Concept Description Languages
• Non-monotonic Logic
© Daniel S. Weld 3
Basic Idea of Logic
© Daniel S. Weld 4
Truth
•Francis Bacon (1561-1626) •Blaise Pascal (1623-1662)
No pleasure is comparable to the We know the truth, not only by
standing upon the vantage-ground the reason, but also by the heart.
of truth.
•François Rabelais (c. 1490-1553)
•Thomas Henry Huxley (1825- Speak the truth and shame the
1895) Devil.
Irrationally held truths may be
more harmful than reasoned •Daniel Webster (1782-1852)
errors.
There is nothing so powerful as
truth, and often nothing so
•John Keats (1795-1821) strange.
Beauty is truth, truth beauty; that
is all ye know on earth, and all ye
need to know.
© Daniel S. Weld 5
Components of KR
• Syntax: defines the sentences in the language
• Semantics: defines the “meaning” of sentences
• Inference Procedure
– Algorithm
– Sound?
– Complete?
– Complexity
• Knowledge Base
© Daniel S. Weld 6
Knowledge bases
• Then it can Ask itself what to do - answers should follow from the KB
© Daniel S. Weld 8
Propositional Logic: Syntax
• Atoms
– P, Q, R, …
• Literals
– P, P
• Sentences
– Any literal is a sentence
– If S is a sentence
• Then (S S) is a sentence
• Then (S S) is a sentence
• Conveniences
P Q same as P Q
© Daniel S. Weld 9
Semantics
• Syntax: which arrangements of symbols are legal
– (Def “sentences”)
• Semantics: what the symbols mean in the world
– (Mapping between symbols and worlds)
Inference
Sentences Sentences
Semantics
Semantics
Representation
World
Facts Facts
© Daniel S. Weld 10
Propositional Logic: SEMANTICS
Q Q
T F T F
T T F T T T
P P
F F F F T F
PQ PQ
© Daniel S. Weld 11
Satisfiability, Validity, & Entailment
© Daniel S. Weld 12
Examples
PQ
R R
S (W S)
T T
XX
© Daniel S. Weld 13
Notation
}
Implication (syntactic symbol)
Inference
Proves: S1 |-i S2 if inference algo, i, says `S2’ from S1
Entailment
= Entails: S1 |= S2 if wherever S1 is true S2 is also true
• Sound =
• Complete =
= implies
© Daniel S. Weld 14
Prop. Logic: Knowledge Engr
1) One of the women is a biology major
2) Lisa is not next to Dave in the ranking
3) Dave is immediately ahead of Jim
4) Jim is immediately ahead of a bio major
5) Mary or Lisa is ranked first
© Daniel S. Weld 15
Reasoning Tasks
• Model finding
KB = background knowledge
S = description of problem
Show (KB S) is satisfiable
A kind of constraint satisfaction
• Deduction
S = question
Prove that KB |= S
Two approaches:
• Rules to derive new formulas from old (inference)
• Show (KB S) is unsatisfiable
© Daniel S. Weld 16
Special Syntactic Forms
• General Form:
((q r) s)) (s t)
• Conjunction Normal Form (CNF)
( q r s ) ( s t)
Set notation: { ( q, r, s ), ( s, t) }
empty clause () = false
• Binary clauses: 1 or 2 literals per clause
( q r) ( s t)
• Horn clauses: 0 or 1 positive literal per clause
( q r s ) ( s t)
(qr) s (st) false
© Daniel S. Weld 17
Propositional Logic: Inference
© Daniel S. Weld 18
Inference 1: Forward Chaining
Forward Chaining
Based on rule of modus ponens
If know P1, …, Pn & know (P1 ... Pn ) Q
Then can conclude Q
© Daniel S. Weld 19
Analysis
• Sound?
• Complete?
Can you prove
{ } |= Q Q
© Daniel S. Weld 20
Example
2 2
Example
1 1
Example
1 0
Example
1 0
Example
1 0
Example
1 0
Example
1 0
Example
0 0
Example
0 0
Propositional Logic: Inference
A mechanical process for computing new sentences
© Daniel S. Weld 30
Conversion to CNF
Inference 2: Resolution
[Robinson 1965]
{ (p ), ( p ) } |-R ( )
Correctness
If S1 |-R S2 then S1 |= S2
Refutation Completeness:
If S is unsatisfiable then S |-R ()
© Daniel S. Weld 32
Resolution
If the unicorn is mythical, then it is immortal, but if
it is not mythical, it is a mammal. If the unicorn is
either immortal or a mammal, then it is horned.
Prove: the unicorn is horned.
( A H) ( H) (I H)
()
© Daniel S. Weld 33
Resolution as Search
• States?
• Operators
© Daniel S. Weld 34
Model Finding
• a CSP
Inference 3: Model Enumeration
© Daniel S. Weld 36
Inference 4: DPLL
(Enumeration of Partial Models)
[Davis, Putnam, Loveland & Logemann 1962]
Version 1
dpll_1(pa){
if (pa makes F false) return false;
if (pa makes F true) return true;
choose P in F;
if (dpll_1(pa {P=0})) return true;
return dpll_1(pa {P=1});
}
(a b c)
(a ¬b)
(a ¬c)
(¬a c)
© Daniel S. Weld 38
DPLL Version 1
a
F
(a b c)
(a ¬b)
(a ¬c)
(¬a c)
© Daniel S. Weld 39
DPLL Version 1
a
F
(F b c)
(F ¬b)
(F ¬c)
(T c)
© Daniel S. Weld 40
DPLL Version 1
a
F
(F F c)
(F T) b
(F ¬c)
(T c)
© Daniel S. Weld 41
DPLL Version 1
a
F
(F F F)
(F T) b
(F T)
c
(T F)
© Daniel S. Weld 42
DPLL Version 1
a
F
F
T b
T
c
T
© Daniel S. Weld 43
DPLL Version 1
a
(a b c)
(a ¬b) b
(a ¬c)
c
(¬a c)
© Daniel S. Weld 44
DPLL Version 1
a
(a b c)
b
(a ¬b) b
(a ¬c)
c
c
(¬a c)
© Daniel S. Weld 45
DPLL as Search
• Search Space?
• Algorithm?
© Daniel S. Weld 46
Improving DPLL
© Daniel S. Weld 47
Improving DPLL
© Daniel S. Weld 48
Improving DPLL
© Daniel S. Weld 49
DPLL version 2
dpll_2(F, literal){
remove clauses containing literal
if (F contains no clauses)return true;
shorten clauses containing literal
if (F contains empty clause)
return false;
choose V in F;
if (dpll_2(F, V))return true;
return dpll_2(F, V);
}
© Daniel S. Weld 50
DPLL Version 2
a
F
(F b c)
(F ¬b)
(F ¬c)
(T c)
© Daniel S. Weld 51
DPLL Version 2
a
(b c)
(¬b)
(¬c)
© Daniel S. Weld 52
DPLL Version 2
a
(F c)
(T) b
(¬c)
© Daniel S. Weld 53
DPLL Version 2
a
(c)
b
(¬c)
© Daniel S. Weld 54
DPLL Version 2
a
(F)
b
(T)
c
© Daniel S. Weld 55
DPLL Version 2
a
()
b
© Daniel S. Weld 56
DPLL Version 2
a
F
(F F F)
(F T) b
(F T)
c
(T F)
© Daniel S. Weld 57
DPLL Version 2
a
F
F
T b
T
c
T
© Daniel S. Weld 58
DPLL Version 2
a
(a b c)
(a ¬b) b
(a ¬c)
c
(¬a c)
© Daniel S. Weld 59
Benefit
© Daniel S. Weld 60
Structure in Clauses
• Unit Literals
A literal that appears in a singleton clause
{{b c}{c}{a b e}{d b}{e a c}}
Might as well set it true! And simplify
{{b} {a b e}{d b}}
{{d}}
• Pure Literals
– A symbol that always appears with same sign
– {{a b c} {c d e} {a b e}{d b} {e a c}}
Might as well set it true! And simplify
{{a b c} {a b e} {e a c}}
© Daniel S. Weld 61
In Other Words
Form ula ( L ) C 2 C 3 ... is only true w hen literal L is true
T herefore: B ranch im m ediately on unit litera ls!
If literal L does not appear negated in form ula F , then setting
L true preserves satisfiability o f F
T herefore: B ranch im m ediately on pure liter als!
(a ¬c)
c
(¬a c)
© Daniel S. Weld 66
DPLL (for real!)
Davis – Putnam – Loveland – Logemann
dpll(F, literal){
remove clauses containing literal
if (F contains no clauses) return true;
shorten clauses containing literal
if (F contains empty clause)
return false;
if (F contains a unit or pure L)
return dpll(F, L);
choose V in F;
if (dpll(F, V))return true;
return dpll(F, V);
}
© Daniel S. Weld 67
Heuristic Search in DPLL
© Daniel S. Weld 68
Success of DPLL
© Daniel S. Weld 69
WalkSat (Take 1)
• Local search (Hill Climbing + Random Walk) over
space of complete truth assignments
–With prob p: flip any variable in any unsatisfied clause
–With prob (1-p): flip best variable in any unsat clause
• best = one which minimizes #unsatisfied clauses
• Each flip
– makes some false clauses become true
– breaks some true clauses, that become false
• Suppose s1s2 by flipping x. Then:
#unsat(s2) = #unsat(s1) – make(s1,x) + break(s1,x)
• Idea 1: if a choice breaks nothing, it is very likely to
be a good move
• Idea 2: near the solution, only the break count
matters
– the make count is usually 1
Walksat (Take 2)
state = random truth assignment;
while ! GoalTest(state) do
clause := random member { C | C is false in state };
for each x in clause do compute break[x];
if exists x with break[x]=0 then var := x;
else
with probability p do
var := random member { x | x is in clause };
else
var := arg x min { break[x] | x is in clause };
endif
state[var] := 1 – state[var];
end
return state; Put everything inside of a restart loop.
Parameters: p, max_flips, max_runs
Random 3-SAT
• Random 3-SAT
– sample uniformly from
space of all possible 3-
clauses
– n variables, l clauses
73
Random 3-SAT
• Varying problem size, n