logical agents; fol - nottinghampsznza/g52pas/lecture7b.pdf · outline ♦ first-order logic ♦...

21
Planning and search Logical agents; FOL Logical agents; FOL 1

Upload: buidung

Post on 30-Sep-2018

220 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Planning and search

Logical agents; FOL

Logical agents; FOL 1

Page 2: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Outline

♦ First-order logic

♦ Syntax

♦ Semantics

♦ What can we express

Logical agents; FOL 2

Page 3: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

First-order logic

Whereas propositional logic assumes world contains facts,first-order logic (like natural language) assumes 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. . .

Logical agents; FOL 3

Page 4: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Logics in general

Language Ontological EpistemologicalCommitment Commitment

Propositional logic facts true/false/unknownFirst-order logic facts, objects, relations true/false/unknownTemporal logic facts, objects, relations, times true/false/unknownProbability theory facts degree of beliefFuzzy logic facts + degree of truth known interval value

Logical agents; FOL 4

Page 5: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Syntax of FOL: Basic elements

Constants KingJohn, 2, UCB, . . .

Predicates Brother, >, . . .

Functions Sqrt, LeftLegOf, . . .

Variables x, y, a, b, . . .

Connectives ∧ ∨ ¬ ⇒ ⇔Equality =Quantifiers ∀ ∃

Logical agents; FOL 5

Page 6: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Atomic sentences

Atomic sentence = predicate(term1, . . . , termn)or term1 = term2

Term = function(term1, . . . , termn)or constant or variable

E.g., Brother(KingJohn,RichardTheLionheart)> (Length(LeftLegOf(Richard)), Length(LeftLegOf(KingJohn)))

Logical agents; FOL 6

Page 7: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Complex sentences

Complex sentences are made from atomic sentences using connectives

¬S, S1 ∧ S2, S1 ∨ S2, S1 ⇒ S2, S1 ⇔ S2

E.g. Sibling(KingJohn,Richard) ⇒ Sibling(Richard,KingJohn)>(1, 2) ∨ ≤(1, 2)>(1, 2) ∧ ¬>(1, 2)

Logical agents; FOL 7

Page 8: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Truth in first-order logic

Sentences are true with respect to a model and an interpretation

Model contains ≥ 1 objects (domain elements) and relations among them

Interpretation specifies referents forconstant symbols → objectspredicate symbols → relationsfunction symbols → functional relations

An atomic sentence predicate(term1, . . . , termn) is trueiff the objects referred to by term1, . . . , termn

are in the relation referred to by predicate

Logical agents; FOL 8

Page 9: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Models for FOL: Example

R J$

left leg left leg

on headbrother

brother

personpersonking

crown

Logical agents; FOL 9

Page 10: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Truth example

Consider the interpretation in whichRichard → Richard the LionheartJohn → the evil King JohnBrother → the brotherhood relation

Under this interpretation, Brother(Richard, John) is truejust in case Richard the Lionheart and the evil King Johnare in the brotherhood relation in the model

Logical agents; FOL 10

Page 11: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Models for FOL: Lots!

Entailment in propositional logic can be computed by enumerating models

We can enumerate the FOL models for a given KB vocabulary:

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 objectsFor 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!

Logical agents; FOL 11

Page 12: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Universal quantification

∀ 〈variables〉 〈sentence〉

Everyone at Berkeley is smart:∀x At(x,Berkeley) ⇒ Smart(x)

∀x P is true in a model m iff P is true with x beingeach possible object in the model

Roughly speaking, equivalent to the conjunction of instantiations of P

(At(KingJohn,Berkeley) ⇒ Smart(KingJohn))∧ (At(Richard,Berkeley) ⇒ Smart(Richard))∧ (At(Berkeley,Berkeley) ⇒ Smart(Berkeley))∧ . . .

Logical agents; FOL 12

Page 13: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

A common mistake to avoid

Typically, ⇒ is the main connective with ∀

Common mistake: using ∧ as the main connective with ∀:

∀x At(x, Berkeley) ∧ Smart(x)

means “Everyone is at Berkeley and everyone is smart”

Logical agents; FOL 13

Page 14: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Existential quantification

∃ 〈variables〉 〈sentence〉

Someone at Stanford is smart:∃x At(x, Stanford) ∧ Smart(x)

∃x P is true in a model m iff P is true with x beingsome possible object in the model

Roughly speaking, equivalent to the disjunction of instantiations of P

(At(KingJohn, Stanford) ∧ Smart(KingJohn))∨ (At(Richard, Stanford) ∧ Smart(Richard))∨ (At(Stanford, Stanford) ∧ Smart(Stanford))∨ . . .

Logical agents; FOL 14

Page 15: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Another common mistake to avoid

Typically, ∧ is the main connective with ∃

Common mistake: using ⇒ as the main connective with ∃:

∃x At(x, Stanford) ⇒ Smart(x)

is true if there is anyone who is not at Stanford!

Logical agents; FOL 15

Page 16: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Properties of quantifiers

∀x ∀ y is the same as ∀ y ∀ x (why??)

∃x ∃ y is the same as ∃ y ∃ x (why??)

∃x ∀ y is not the same as ∀ y ∃x

∃x ∀ y Loves(x, y)“There is a person who loves everyone in the world”

∀ y ∃ x Loves(x, y)“Everyone in the world is loved by at least one person”

Quantifier duality: each can be expressed using the other

∀x Likes(x, IceCream) ¬∃x ¬Likes(x, IceCream)

∃x Likes(x,Broccoli) ¬∀ x ¬Likes(x,Broccoli)

Logical agents; FOL 16

Page 17: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Fun with sentences

Brothers are siblings

Logical agents; FOL 17

Page 18: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Fun with sentences

Brothers are siblings

∀x, y Brother(x, y) ⇒ Sibling(x, y).

“Sibling” is symmetric

Logical agents; FOL 18

Page 19: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Fun with sentences

Brothers are siblings

∀x, y Brother(x, y) ⇒ Sibling(x, y).

“Sibling” is symmetric

∀x, y Sibling(x, y) ⇔ Sibling(y, x).

One’s mother is one’s female parent

Logical agents; FOL 19

Page 20: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Fun with sentences

Brothers are siblings

∀x, y Brother(x, y) ⇒ Sibling(x, y).

“Sibling” is symmetric

∀x, y Sibling(x, y) ⇔ Sibling(y, x).

One’s mother is one’s female parent

∀x, y Mother(x, y) ⇔ (Female(x) ∧ Parent(x, y)).

A first cousin is a child of a parent’s sibling

Logical agents; FOL 20

Page 21: Logical agents; FOL - Nottinghampsznza/G52PAS/lecture7b.pdf · Outline ♦ First-order logic ♦ Syntax ♦ Semantics ♦ What can we express Logical agents; FOL 2

Fun with sentences

Brothers are siblings

∀x, y Brother(x, y) ⇒ Sibling(x, y).

“Sibling” is symmetric

∀x, y Sibling(x, y) ⇔ Sibling(y, x).

One’s mother is one’s female parent

∀x, y Mother(x, y) ⇔ (Female(x) ∧ Parent(x, y)).

A first cousin is a child of a parent’s sibling

∀x, y F irstCousin(x, y) ⇔ ∃ p, ps Parent(p, x) ∧ Sibling(ps, p) ∧Parent(ps, y)

Logical agents; FOL 21