Upload
parson
View
35
Download
0
Tags:
Embed Size (px)
DESCRIPTION
CS 541: Artificial Intelligence. Lecture IV: Logic Agent and First Order Logic. Announcement. CA Office Hour: 3:00pm-4:00pm, Lieb 319. Homework assignment should be checked at Moodle. Schedule. Re-cap Lecture III. Constraint Satisfaction Problem - PowerPoint PPT Presentation
Citation preview
CS 541: Artificial Intelligence
Lecture IV: Logic Agent and First Order Logic
Announcement CA Office Hour: 3:00pm-4:00pm, Lieb 319.
Homework assignment should be checked at Moodle.
ScheduleWeek Date Topic Reading Homework**
1 08/29/2012 Introduction & Intelligent Agent Ch 1 & 2 N/A
2 09/05/2012 Search: search strategy and heuristic search Ch 3 & 4s HW1 (Search)
3 09/12/2012 Search: Constraint Satisfaction & Adversarial Search Ch 4s & 5 & 6 Teaming Due
4 09/19/2012 Logic: Logic Agent & First Order Logic Ch 7 & 8s HW1 due, Midterm Project (Game)
5 09/26/2012 Logic: Inference on First Order Logic Ch 8s & 9 6 10/03/2012 No class 7 10/10/2012 Uncertainty and Bayesian Network Ch 13 &
Ch14s HW2 (Logic)
8 10/17/2012 Midterm Presentation Midterm Project Due
9 10/24/2012 Inference in Baysian Network Ch 14s HW2 Due, HW3 (Probabilistic Reasoning)
10 10/31/2012 Probabilistic Reasoning over Time Ch 15 11 11/07/2012 Machine Learning HW3 due,
12 11/14/2012 Markov Decision Process Ch 18 & 20 HW4 (Probabilistic Reasoning Over Time)
13 11/21/2012 No class Ch 16 14 11/29/2012 Reinforcement learning Ch 21 HW4 due
15 12/05/2012 Final Project Presentation Final Project Due
Re-cap Lecture III Constraint Satisfaction Problem
Constraint satisfaction problem (CSP) examples Backtracking search for CSPs Problem structure and problem decomposition Local search for CSPs
Adversarial Search and Games Games Perfect play
Minimax decisions α - β pruning
Resource limits and approximate evaluation Games of chance Games of imperfect information
Logic Agent
Lecture IV: Part I
Outline Knowledge-based agents Wumpus world Logic in general—models and entailment Propositional (Boolean) logic Equivalence, validity, satisfiability Inference rules and theorem proving
Forward chaining Backward chaining Resolution
Knowledge bases
Knowledge base Set of sentences in a formal language
Declarative approach to building an agent (or other system) TELL it what is needs to know
Then it can ASK itself what to do Answers should follow from the KB
Agents can be viewed at the knowledge level i.e., what they know, regardless of how implemented
Or at the implementation level i.e., data structures in KB and algorithms that manipulate them
A simple knowledge-based agent
The agent must be able to: Represent states, actions, etc. Incorporate new percepts Update internal representations of the world Deduce hidden properties of the world Deduce appropriate actions
Wumpus world PEAS description Performance measure
Gold +1000; Death -1000 -1 per step; -10 for using the arrow
Environment Squares adjacent to wumpus are smelly Squares adjacent to pit are breezy Glitter iff gold is in the same square Shooting kills wumpus if you are facing it Grabbing picks up gold if in same square Releasing drops the gold in same square
Actuators Left turn, right turn, forward, grab, release,
shoot Sensors
Breeze, glitter, smell
Wumpus world characterization Observable??
No, only local perception Deterministic??
Yes, outcomes exactly specified Episodic??
No, sequential at the level of actions Static??
Wumpus and pits do not move Discrete??
Yes Single-agent??
Yes, Wumpus is essentially a natural feature
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Exploring a wumpus world
Other tight spots Breeze in (1,2) and (2, 1)
No safe actions
Smell in (1,1) Cannot move
Can use a strategy of coercion Shoot straight ahead Wumpus was theredeadsafe Wumpus wasn’t there safe
Logic in general Logics are formal languages for representing
information Such that conclusions can be drawn
Syntax defines the sentences in the language Semantics define the “meaning” of sentences
i.e., define truth of a sentence in a world E.g., the language of arithematics
x+2≥y is a sentence; x2+2> is not a sentence x+2≥y is true iff the number x+2 is no less than the number y x+2≥y is true in a world where x=7, y=1 x+2≥y is false in a world where x=0, y=6
Entailment Entailment means that one thing follows from
another
Knowledge base KB entails sentence If and only if is true in all worlds where KB is true E.g., the KB containing “the giants won” and “the
Reds won” entails “Either the Giants won or the Reds won”
E.g., x+y=4 entails 4=x+y Entailment is a relationship between sentences
(i.e., syntax) that is based on semantics Note: brains process syntax (of some sort)
Models Logicians typically think in terms of models,
which are formally structured worlds with respect to which truth can be evaluated
We say m is a model of a sentence is the set of all models of
Then if and only if E.g, KB=Giants won and Reds won, and =Giants won
Entailment in the wumpus world Situation after detecting nothing in
[1,1], moving right, breeze in [2,1] Consider possible models for ?s
assuming only pits 3 Boolean choices 8 possible
models
Wumpus models
Wumpus models
KB=wumpus-world rules+observations
Wumpus models
KB=wumpus-world rules+observations =“[1,2] is safe”, , proved by model checking
Wumpus models
KB=wumpus-world rules+observations
Wumpus models
KB=wumpus-world rules+observations =“[2,2] is safe”,
Inference = sentence can be derived from KB by procedure i Consequences of KB are a haystack; is a needle. Entailment = needle in haystack; inference=finding it! Soundness:
i is sound if whenever , it is also true that Completeness:
i is complete if whenever , it is also true that Preview:
We will define a logic (first-order logic) which is expressive enough to say almost anything of interest, and for which there exists a sound and complete inference procedure
i.e., the procedure will answer any question whose answer follows from what is known about KB
Propositional logic: Syntax Propositional logic is the simplest logic—
illustrates basic ideas The proposition symbols P1, P2 etc. are
sentences If S is a sentence, is a sentence (negation) If and are sentences, is a sentence (conjunction) If and are sentences, is a sentence (disjunction) If and are sentences, is a sentence (implication) If and are sentences, is a sentence (bicondition)
Propositional logic: Semantics Each model specifies true/false for each proposition symbol
E.g., true true true With these symbols, 8 possible models, can be enumerated
automatically Rules for evaluating truth with respect to a model m:
is true iff is false is true iff is true and is true is true iff is true or is true is true iff is false or is truei.e., is false iff is true and is false is true iff is true or is true
Simple recursive process evaluates an arbitrary sentence, e.g.,
Truth tables for connectives
Wumpus world sentences Let be true if there is a pit in [i,j] Let be true if there is a breeze in [i,j]
“Pits cause breezes in adjacent squares”
“A square is breezy if and only if there is an adjacent pit”
Truth tables for inference
Enumerate rows (different assignments to symbols)
If KB is true in row, check that is too
Inference by enumeration Depth-first enumeration of all models in sound and complete
for n symbols; problem is co-NP-complete
Logical equivalence Two sentences are logically equivalent iff true in
same models: if and only if and
Validity and satisfiability A sentence is valid if it is true in all models
E.g., Validity is connected to inference via the Deduction
Theorem if and only if is valid
A sentence is satisfiable if it is true in some models E.g.,
A sentence is unsatisfiable if it is true in no model E.g.,
Satisfiability is connected to inference via the following: if and only if is unsatisfiable i.e., prove by reductio ad absurdum
Proof methods Proof methods divide into (roughly) two kinds: Application of inference rules
Legitimate (sound) generation of new sentences from old Proof = a sequence of inference rule applications
Can use inference rules as operators in a standard search algorithm
Typically require translation of sentences into a norm form Model checking
Truth table enumeration (always exponential in n) Improved backtracking, e.g., Davis-Putnam-Logemann-
Loveland (DPLL) Heurisitc search in model space (sound but incomplete)
E.g., min-conflicts-like hill-climbing algorithms
Horn From (restricted) KB=conjunction of Horn clauses Horn clause =
Proposition symbol (Conjunction of symbols) symbol E.g.,
Modus Ponens (for Horn Form): complete for Horn KBs
Can be used with forward chaining or backward chaining
These algorithms are very natural and run in linear time
Forward and backward chaining
Idea: fire any rule whose premises are satisfied in the KB, add its conclusion to the KB, until query is found
Forward chaining
Forward chaining algorithm
Forward chaining example
Forward chaining example
Forward chaining example
Forward chaining example
Forward chaining example
Forward chaining example
Forward chaining example
Forward chaining example
Proof of completeness FC derives every atomic sentence that is entailed by KB
FC reaches a fixed point where no new atomic sentences are derived
Consider the final state as a model m, assigning true/false to symbols
Every clause in the original KB is true in m Proof: Suppose a clause is false in mThen is true in m and b is false in mTherefore the algorithm has not reached a fixed point
Hence m is a model of KB If , q is true in every model of KB, including m General idea: construct any model of KB by sound inference, check
Backward chaining Idea: work backwards from the query q:
To prove q by BC, check if q is known already, or, prove by BC all premises of some rule concluding q
Avoid loops: check if new subgoal is already on the goal stack
Avoid repeated work: check if new sub goal Has already been proven true, or Has already failed
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Backward chaining example
Forward vs. backward chaining FC is data-driven, cf. automatic, unconscious
processing E.g., object recognition, routine decisions
May do lots of work that is irrelevant to the goal BC is goal-driven, appropriate for problem-solving
E.g., where are my keys? How do I get into a PhD program? Complexity of BC can be much less than linear in size of KB
Resolution Conjunctive Normal Form (CNF—universal)
Conjunction of disjunctions of literals E.g.,
Resolution inference rule (for CNF): complete for propositional logic
where li and mj are complementary literals. E.g,
Resolution is sound and complete complete for propositional logic
Conversion to CNF
1. Eliminate , replacing with 2. Eliminate , replacing with 3. Move inwards using de Morgan’s rules and double-negation 4. Apply distributivity law ( over ) and flatten:
Resolution algorithm Proof of contradiction, i.e., show unsatisfiable
Resolution example
Summary Logical agents apply inference to a knowledge base to derive
new information and make decisions Basic concepts of logic:
Syntax: formal structure of sentences Semantics: truth of sentences wrt models Entailment: necessary truth of one sentence given another Inference: deriving sentences from other sentences Soundess: derivations produce only entailed sentences Completeness: derivations can produce all entailed sentences
Wumpus world requires the ability to represent partial and negated information, reason by cases, etc.
Forward, backward chaining are linear-time, complete for Horn clauses
Resolution is complete for propositional logic Propositional logic lacks expressive power
First-order Logic
Lecture IV: Part II
Outline Why first-order logic (FOL)? Syntax and semantics of FOL Fun with sentences Wumpus world in FOL
Pros and cons of propositional logic Propositional logic is declarative: pieces of syntax
correspond to facts Propositional logic allows partial/disjunctive/negated
information Unlike most data structures and databases
Propositional logic is compositional: Meaning of is derived from meaning of and of
Meaning in propositional logic is context-independent Unlike natural language, where meaning depends on context
Propositional logic has very limited expressive power Unlike natural language E.g., cannot say “pits cause breezes in adjacent squares” except by
writing one sentence for each square
First-order logic Whereas propositional logic assumes world contains facts, First-order logic (like natural language) assumes that the world
contains Objects: people, houses, numbers, theories, Ronald McDonald, colors,
baseball games, wars, centuries … Relations: red, round, bogus, prime, multistoried…, brother of, bigger
than, inside, part of, has color, occurred after, owns, comes between, … Functions: father of, best friend, third inning of, one more than, end of…
Logics in general
Syntax of FOL: Basic elements Constants: King John, 2, Stevens Predicates: Brother, >, … Functions: Sqrt, LeftLegOf,… Variables: x, y, a, b, … Connectives: Equality: = Quantifiers
Atomic sentences Atomic sentence = predicate(term1, …, termn) Or term1=term2
Term=function(term1,…,termn) or constant or variable
E.g., Brother(King John, RichardTheLinonHeart)
>(Length(LeftLegOf(Richard))), Length(LeftLegOf(KingJohn)))
Complex sentences Complex sentences are made from atomic sentences using
connectives E.g.
Truth in first-order logic Sentences are true with respect to a model
and an interpretation Model contains objects (domain elements)
and relations among them Interpretation specifies referents for
Constant symbols objects Predicate symbols relations Function symbols functional relations
An atomic sentence predicate(term1,…, termn) is true Iff the objects referred by term1, …, termn are in
the relations referred to by predicate
Models for FOL: example
Truth example Consider the interpretation in which
Richard Richard the Lionheart John the evil King John Brother The brotherhood relation
Under this interpretation, Brother(Richard, John) is true, just in case Richard the Liohheart and the evil King John are in the brotherhood relation in the model
Models of FOL: lots! Entailment in propositional logic can be computed by
enumerating models We can enumerate the FOL models for a given KB
vocabulary, i.e., For each number of domain elements n from 1 to ∞
For each k-ary predicate Pk in the vocabulary For each possible k-ary relation on n objects
For each constant symbol C in the vocabulary For each choice of referent for C from n Objects …
Computing entailment by enumerating FOL models is not easy!
Universal quantification
Everyone at Stevens is smart
is true in a model m iff P is true with x being each possible object in the model
Roughly speaking, equivalent to the conjunction of instantiations of P
A common mistake to avoid Typically, is the main connective with Common mistake: using as the main
connective with : means “Everyone is at Stevens and everyone is
smart”.
Existential quantification
Someone at RPI is smart:
is true in a model m iff P is true with x being some possible object in the model
Roughly speaking, equivalent to the disjunction of instantiations of P
Another common mistake to avoid Typically, is the main connective with Common mistake: using as the main
connective with :
is true if there is anyone who is not at RPI!
Properties of quantifiers is the same as is the same as is not the same as
“There is a person who loves everyone in the world”
“Everyone in the world is loved by at least one person” Quantifier duality: each can be expressed using
the other
Fun with sentences Brothers are siblings
“Sibling” is symmetric
One’s mother is one’s female parent
A first counsin is a child of a parent’s sibling
Equality term1=term2 is true under a given
interpretation if and only if term1 and term2 refer to the same object, e.g., and are satisfiable is valid Definition of (full) Sibling in terms of Parent:
Interacting with FOL KBs Suppose a wumpus-world agent is using an FOL KB and
perceives a smell and a breeze (but no glitter) at t=5: I.e., does KB entail any particular actions at t=5? Answer: Yes, {aShoot} substitution (binding list) Given a sentence S and a substitution , denotes the result of plugging into ; e.g.,
returns some/all such that
Knowledge base for the wumpus world “Perception”
Reflex: Reflex with internal state: do we have the
gold already? can not be observed
keeping track of changes is essential
Deducing hidden properties Properties of locations:
Squares are breezy near a pit: Diagnostic rule—infer cause from effect
Causal rule—infer from cause
Neither of these is complete—e.g., the causal rule doesn’t say whether squares far away from pits can be breezy
Definition for the Breezy predicate
Keeping track of change Facts hold in situations, rather than eternally
E.g., rather than just Situation calculus is one way to represent change in FOL:
Adds a situation argument to each non-eternal predicate E.g., Now in denotes a situation
Situation are connected by the Result function is the situation that results from doing a in s
Describing actions I “Effect” axiom—describe changes due to action “Frame” axiom—describe non-changes due to action Frame problem: find an elegant way to handle non-change
Representation –avoid frame axioms Inference—avoid repeated “copy-overs” to keep track of state
Quantification problem: true descriptions of real actions require endless caveats—what if gold is slippery or nailed down or …
Ramification problem: real actions have many secondary consequences—what about the dust on the gold, wear and tear on gloves, …
Describing actions II Successor-state axioms solve the representational
frame problem Each axiom is “about” a predicate (not an action
per se):
For holding the gold
Making plans Initial condition in KB:
Query: i.e., in what situation will I be holding the gold?
Answer: i.e., go forward and then grab the gold
This assumes that the agent is interested in plans starting at S0 and that S0 is the only situation described in the KB
Making plans: A better way Represent plans as action sequences is the result of executing p in s Then the query has the solution Definition of PlanResutlt in terms of Result: Planning systems are special-purpose reasoners
designed to do this type of inference more efficiently than a general-purpose reasoner
Summary First-order logic:
Objects and relations are semantic primitives Syntax: constants, functions, predicates, equality,
quantiers Increased expressive power: sufficient to define
wumpus world Situation calculus:
Conventions for describing actions and change in FOL Can formulate planning as inference on a situation
calculus KB
Midterm Mastermind (midterm)
http://en.wikipedia.org/wiki/Mastermind_%28board_game%29 Base problem: Guessing of 4 digit numbers without repetition What to submit?
A report summarizing the algorithm you adopted and implemented The report should come with related technical papers you read The report should include complexity analysis (worst case) The report should also include empirical performance.
Source code and executable with detailed ReadMe on how to run it Code implementation:
A starter program which generates a random 4 or n digit numbers without repetition A master program which can check the number of matched digits and positions of
your guessed number from your main program and the target number (hidden) The input is your guessed number, the output is of style mAnB stands for m digits are
guessed correctly with correct positions, with n other digits guessed correctly but with wrong positions.
A main program which guesses the target number and interacts with your master program to get feedback and re-guessing
Your main program should also be able to get feedback with dumb “keyboard input”.