csc384: introduction to artificial intelligencetorsten/csc384-f11/lectures/csc384f11... ·...

159
1 Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University of Toronto, Fall 2011 CSC384: Introduction to Artificial Intelligence Instructor: Torsten Hahmann • Office Hour: Wednesday 6:00 – 7:00 pm, BA2200 • tentative, starting Sept. 21 • I will be offering more office hours as needed and we will have labs (by TAs) for assignments • Make use of the office hours – they are not just for administrative things, but also if you have questions about the material Please ask questions during lecture • If you don’t understand, it is likely others don’t understand! • Break during lectures: 15min in the middle?

Upload: others

Post on 14-Jul-2020

18 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

1Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

CSC384: Introduction to Artificial Intelligence

• Instructor: Torsten Hahmann

• Office Hour: Wednesday 6:00 – 7:00 pm, BA2200

• tentative, starting Sept. 21

• I will be offering more office hours as needed and we will

have labs (by TAs) for assignments

• Make use of the office hours – they are not just for

administrative things, but also if you have questions about

the material

• Please ask questions during lecture

• If you don’t understand, it is likely others don’t understand!

• Break during lectures: 15min in the middle?

Page 2: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

2Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

First AI Research Day

• Tuesday, September 27, 2011, learn about artificial intelligence at U of T• Learn about the research happening right here in the A.I.

department

• Find out about other AI courses you can take.

• Ask questions about grad school and research opportunities

• 4 to 6 pm (BA1180): Introductory talks by CS profs and grad students about their respective fields. • No prior knowledge is assumed.

• 6 to 7:30 pm (BA3200): Reception• Mingle with CS profs and grad students, and ask your burning

questions

• Free food

Page 3: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

3Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Acknowledgements

• Much of the material in this slide deck comes from Fahiem Bacchus,

who according to lore refined slides of Craig Boutilier.

• Sheila McIlraith contributed significantly to these slides.

• Hojjat Ghaderi has contributed to these slides.

• Some slides and examples taken from Maryam Fazel-Zarandi.

• Rich Zemel may have contributed to these slides.

• Some slides come from a tutorial by Andrew Moore via Sonya Alin.

• Some slides come from Hwee Tou Ng's AI course.

• I suspect there are also slides in here from Russell & Norvig.

• Thanks to all.

Page 4: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

4Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Last week: Different ways of looking at intelligence

• Four kinds (by Russell & Norvig):

Systems that act rationallySystems that act like

humans

Systems that think rationallySystems that think like

humans

Not necessarily like humansLike humans

Think

Act

Our focus

Cognitive Science

Weak AI

Strong AI

Page 5: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

5Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Last week: Recent successes in AI

Watson competing on Jeopardy

… involves lots of search!

• One of the most basic techniques in AI

• Can solve many problems with lots of computing

power that humans are not good not

• Does not try to mimick how humans think

Page 6: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

6Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

How do we plan our holiday?

• We must take into account various preferences and

constraints to develop a schedule.

• An important technique in developing such a schedule is

“hypothetical” reasoning.

• Example: On holiday in Romania

• Currently in Arad

• Flight leaves tomorrow from Bucharest

Page 7: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

7Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

How do we plan our holiday?

• This kind of hypothetical reasoning involves asking

• “what state will I be in after the following sequence of events?”

• From this we can reason about what sequence of

events one should try to bring about to achieve a

desirable state.

• Search is a computational method for capturing a

particular version of this kind of reasoning.

Page 8: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

8Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Search Used in Goal-based Agents

Page 9: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

9Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Many problems similar to that:

Page 10: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

10Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Why Search

• Successful

• Success in game playing programs based on search.

• Many other AI problems can be successfully solved by search.

• Practical

• Many problems don’t have a simple algorithmic solution. Casting these problems as search problems is often the easiest way of solving them. Search can also be useful in approximation (e.g., local search in optimization problems).

• Often specialized algorithms cannot be easily modified to take advantage of extra knowledge. Heuristics provide search provides a natural way of utilizing extra knowledge.

• Some critical aspects of intelligent behaviour, e.g., planning, can be naturally cast as search.

Page 11: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

11Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Search

• There are many difficult questions that are not resolved

by search. In particular, the whole question of how does

an intelligent system formulate its problem as a search

problem is not addressed by search.

• Search only shows how to solve the problem once we

have it correctly formulated.

Page 12: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

12Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Today and (at least) next week: Search

Search

• This and next week: Search

• Formulating a problem as search problem (representation)

• Uninformed Search

• Heuristic Search

• Backtracking Search

• Game-Tree-Search

• Readings for today’s lecture:

• Introduction: Chapter 3.1 – 3.3

• Uninformed Search: Chapter 3.4

• Heuristic Search: Chapters 3.5, 3.6

Page 13: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

13Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Representing a problem: The Formalism

To formulate a problem as a search problem we need the

following components:

1. Formulate a state space over which to search. The state

space necessarily involves abstracting the real problem.

2. Formulate actions that allow one to move between

different states. The actions are abstractions of actions

you could actually perform.

3. Identify the initial state that best represents your current

state and the desired condition one wants to achieve.

4. Formulate various heuristics to help guide the search

process (initially we do without).

Page 14: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

14Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

The Formalism

Once the problem has been formulated as a state space

search, various algorithms can be utilized to solve the

problem.

• A solution to the problem will be a sequence of actions/moves

that can transform your current state into state where your

desired condition holds.

Page 15: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

15Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 1: Romania Travel.

Currently in Arad, need to get to Bucharest by tomorrow to

catch a flight. What is the State Space?

Page 16: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

16Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 1.

• State space.

• States: the various cities you could be located in.

• Note we are ignoring the low level details of driving, states

where you are on the road between cities, etc.

• Actions: drive between neighboring cities.

• Initial state: in Arad

• Desired condition (Goal): be in a state where you are in

Bucharest. (How many states satisfy this condition?)

• Solution will be the route, the sequence of cities to

travel through to get to Bucharest.

Page 17: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

17Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 2. The 8-Puzzle

Rule: Can slide a tile into the blank spot. (Equivalently, can

think if it as moving the blank around).

Page 18: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

18Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 2. The 8-Puzzle

• State space.

• States: The different configurations of the tiles. How many

different states?

• Actions: Moving the blank up, down, left, right. Can every

action be performed in every state?

• Initial state: as shown on previous slide.

• Desired condition (Goal): be in a state where the tiles are all

in the positions shown on the previous slide.

• Solution will be a sequence of moves of the blank

that transform the initial state to a goal state.

Page 19: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

19Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 2. The 8-Puzzle

• Although there are 9! different configurations of the

tiles (362,880) in fact the state space is divided into

two disjoint parts.

• Only when the blank is in the middle are all four

actions possible.

• Our goal condition is satisfied by only a single state.

But one could easily have a goal condition like

• The 8 is in the upper left hand corner.

• How many different states satisfy this goal?

Page 20: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

20Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

• In the previous two examples, a state in the search

space corresponded to a unique state of the world

(modulo details we have abstracted away).

• However, states need not map directly to world

configurations. Instead, a state could map to the

agent’s mental conception of how the world is

configured: the agent’s knowledge state.

Page 21: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

21Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

• We have a vacuum cleaner

and two rooms.

• Each room may or may not be

dirty.

• The vacuum cleaner can move

left or right (the action has no

effect if there is no room to

the right/left).

• The vacuum cleaner can suck;

this cleans the room (even if

the room was already clean).

Physical states

Page 22: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

22Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

• The state space can consist

of a set of states. The agent

knows that it is in one of

these states, but doesn’t

know which.

Goal is to have all rooms clean.

Knowledge-level State Space

Page 23: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

23Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

• Complete knowledge of the

world: agent knows exactly

which state it is in. State

space states consist of single

physical states:

• Start in {5}:

<right, suck>

Goal is to have all rooms clean.

Knowledge-level State Space

Page 24: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

24Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

• No knowledge of the world.

States consist of sets of

physical states.

• Start in {1,2,3,4,5,6,7,8}, agent

doesn’t have any knowledge

of where it is.

• Nevertheless, the actions

<right, suck, left, suck>

achieves the goal.

Goal is to have all rooms clean.

Knowledge-level State Space

Page 25: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

25Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

Initial state.

{1,2,3,4,5,6,7,8}

Left

Page 26: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

26Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

Suck

Page 27: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

27Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

Right

Page 28: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

28Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example 3. Vacuum World

Suck

Page 29: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

29Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

More complex situations

• The agent might be able to perform some sensing

actions. These actions change the agent’s mental

state, not the world configuration.

• With sensing can search for a contingent solution: a

solution that is contingent on the outcome of the

sensing actions

• <right, if dirt then suck>

• Now the issue of interleaving execution and search

comes into play.

Page 30: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

30Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

More complex situations

• Instead of complete lack of knowledge, the agent

might think that some states of the world are more

likely than others.

• This leads to probabilistic models of the search space

and different algorithms for solving the problem.

• Later we will see some techniques for reasoning and

making decisions under uncertainty.

Page 31: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

31Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Algorithms for Search

Inputs:

• a specified initial state (a specific world state or a set of

world states representing the agent’s knowledge, etc.)

• a successor function S(x) = {set of states that can be reached

from state x via a single action}.

• a goal test a function that can be applied to a state and

returns true if the state is satisfies the goal condition.

• A step cost function C(x,a,y) which determines the cost of

moving from state x to state y using action a. (C(x,a,y) = ∞ if

a does not yield y from x)

Page 32: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

32Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Algorithms for Search

Output:

• a sequence of states leading from the initial state to a

state satisfying the goal test.

• The sequence might be

• annotated by the name of the action used.

• optimal in cost for some algorithms.

Page 33: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

33Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Algorithms for Search

Obtaining the action sequence.

• The set of successors of a state x might arise from different actions, e.g.,

• x → a → y

• x → b → z

• Successor function S(x) yields a set of states that can be reached from x via a (any) single action.

• Rather than just return a set of states, we might annotate these states by the action used to obtain them:

• S(x) = {<y,a>, <z,b>} y via action a, z via action b.

• S(x) = {<y,a>, <y,b>}y via action a, also y via alternative action b.

Page 34: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

34Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Tree search

• We use the successor state function to simulate an exploration of the state space.

• Initial call has Frontier = initial state.• Frontier is the set of states we haven’t yet explored/expanded, and

want to explore.

TreeSearch(Frontier, Sucessors, Goal? )

If Frontier is empty return failure

Curr = select state from Frontier

If (Goal?(Curr)) return Curr.

Frontier’ = (Frontier – {Curr}) U Successors(Curr)

return TreeSearch(Frontier’, Successors, Goal?)

Page 35: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

35Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Tree search

treeS([[State|Path],_],Soln) :-

goal?(State), reverse([State|Path], Soln).

treeS([[State|Path],Frontier],Soln) :-

genSuccessors(State,Path,NewPaths),

merge(NewPaths,Frontier,NewFrontier),

treeS(NewFrontier,Succ,Soln).

Prolog Implementation:Prolog Implementation:Prolog Implementation:Prolog Implementation:

Page 36: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

36Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

{Arad},

Solution: Arad -> Sibiu -> Fagaras -> Bucharest

Cost: 140 + 99 + 211 = 450

{Z<A>, T<A>, S<A>},

{Z<A>, T<A>, A<S;A>, O<S;A>, F<S;A>, R<S;A>}

{Z<A>, T<A>, A<S;A>, O<S;A>, R<S;A>, S<F;S;A>, B<F;S;A>}

Page 37: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

37Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

{Arad}

Solution: Arad -> Sibiu -> Rimnicu Vilcea -> Pitesti -> Bucharest

Cost: 140 + 80 + 97 + 101 = 418

{Z<A>, T<A>, S<A>},

{Z<A>, T<A>, A<S,A>, O<S,A>, F<S,A>, R<S,A>}

{Z<A>, T<A>, A<S,A>, O<S,A>, F<S,A>, S<R,S,A>, P<R,S,A>, C<R,S,A>}

{Z<A>, T<A>, A<S,A>, O<S,A>, F<S,A>, S<R,S,A>, C<R,S,A>, R<P,R,S,A>, C<P,R,S,A>, Bucharest<P,R,S,A>}

Page 38: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

38Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Frontier is a set of paths not a set of states: cycles become an issue.

… we deal with this issue later!

{Arad}

{Z<A>, T<A>, S<A>},

{Z<A>, T<A>, O<S;A>, F<S;A>, A<S;A>, R<S;A>}

{Z<A>, T<A>, O<S;A>, F<S;A>, R<S;A>, Z<A;S;A>, T<A;S;A>, S<A,S,A>}

…..

Page 39: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

39Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Selection Rule

The example shows that order states are selected from

the frontier has a critical effect on the operation of the

search:

• Whether or not a solution is found

• The cost of the solution found.

• The time and space required by the search.

Page 40: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

40Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

How to select the next node from the frontier?

All search techniques keep a queue of states to be

explored (initially only the initial state) and repeat :

• If the queue is empty, terminate with failure.

• Get the next state from the queue.

• If the state is a goal state, terminate with success.

• Expand the state (i.e. generate the successor states, i.e. all

reachable states), and put the states in the queue. How?

Page 41: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

41Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Critical Properties of Search

• Completeness: will the search always find a solution if a

solution exists?

• Optimality: will the search always find the least cost

solution? (when actions have costs)

• Time complexity: what is the maximum number of nodes

than can be expanded or generated?

• Space complexity: what is the maximum number of

nodes that have to be stored in memory?

Page 42: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

42Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uninformed Search Strategies

• These are strategies that adopt a fixed rule for selecting

the next state to be expanded.

• The rule does not change irrespective of the search

problem being solved.

• These strategies do not take into account any domain

specific information about the particular search

problem.

• Popular uninformed search techniques:• Breadth-First, Uniform-Cost, Depth-First, Depth-Limited, and Iterative-

Deepening search

Page 43: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

43Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Selecting vs. Sorting

• A simple equivalence we will exploit

• Order the elements on the frontier.

• Always select the first element.

• Any selection rule can be achieved by employing an

appropriate ordering of the frontier set.

Page 44: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

44Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Search

Page 45: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

45Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Search

• Place the successors of the current state at the end of

the frontier.

Page 46: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

46Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 47: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

47Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 48: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

48Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 49: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

49Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 50: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

50Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 51: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

51Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Properties

Completeness?

• The length of the path from the initial state to the expanded state must increase monotonically.

• we replace each expanded state with states on longer paths.

• All shorter paths are expanded prior before any longer path.

• Hence, eventually we must examine all paths of length d, and thus find the shortest solution.

Optimality?

• Will find shortest length solution

• least cost solution?

• Not necessarily: shortest solution not always fastest solution

Page 52: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

52Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Solution: Arad -> Sibiu -> Fagaras -> Bucharest

Cost: 140 + 99 + 211 = 450

Solution: Arad -> Sibiu -> Rimnicu Vilcea -> Pitesti -> Bucharest

Cost: 140 + 80 + 97 + 101 = 418

Page 53: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

53Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Properties

Measuring time and space complexity.

• let b be the maximum number of successors of any

state (maximal branching factor).

• let d be the number of actions in the shortest solution

(depth).

Time Complexity?

1 + b + b2 + b3 + … + bd-1 + bd + b(bd – 1) = O(bd+1)

Page 54: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

54Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Properties

Measuring time and space complexity.

• let b be the maximum number of successors of any

state (maximal branching factor).

• let d be the number of actions in the shortest solution

(depth).

Space Complexity?

• O(bd+1): If goal node is last node at level d, all of the

successors of the other nodes will be on the frontier when

the goal node is expanded b(bd – 1)

Page 55: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

55Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Breadth-First Properties

Space complexity is a real problem.

• E.g., let b = 10, and say 1000 nodes can be expanded per second

and each node requires 100 bytes of storage:

11 GB31 hrs.1088

111 MB18 mins.1066

100 bytes1 millisec.11

MemoryTimeNodesDepth

• Run out of space long before we run out of time in

most applications.

Page 56: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

56Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Search

Page 57: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

57Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Search

• Keep the frontier sorted in increasing cost of the path to a node.

• Always expand the least cost node.

• Identical to Breadth first if each transition has the same cost.

Page 58: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

58Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 59: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

59Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 60: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

60Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 61: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

61Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 62: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

62Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 63: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

63Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 64: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

64Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 65: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

65Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 66: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

66Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 67: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

67Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 68: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

68Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 69: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

69Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 70: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

70Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 71: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

71Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 72: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

72Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 73: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

73Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 74: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

74Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 75: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

75Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Properties

Completeness?

• If each transition has costs ≥ ε > 0.

• The previous argument used for breadth first search holds: the cost of the expanded state must increase monotonically.

Optimality?

• Finds optimal solution if each transition has

cost ≥ ε > 0.

• Explores paths in the search space in increasing order of cost. So must find minimum cost path to a goal before finding any higher costs paths.

Page 76: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

76Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Search. Proof of Optimality

Lemma 1.

Let c(n) be the cost of the path to node n in the

frontier. If n2 is expanded RIGHT after n1 then

c(n1) ≤ c(n2).

Proof: there are 2 cases:

a. n2 was on the frontier when n1 was expanded:

We must have c(n2) ≥ c(n1) otherwise n1 would not have been selected for

expansion!

b. n2 was added to the frontier when n was expanded

Again c(n2) ≥ c(n1) since path to n2 extends the path to n1.

Page 77: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

77Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Search. Proof of Optimality

Lemma 2.

When node n is expanded every path with cost strictly less than c(n) has already been expanded (i.e., every node on it has been expanded).

Proof:• Let <Start, n0, n1, …, nk> be a path with cost less than c(n). Let ni be the

last node on this path that has been expanded: <Start, n0, n1, ni-1, ni, ni+1, …, nk>

• So, ni+1 must still be on the frontier. Also c(ni+1) < c(n) since the cost of the entire path to nk is < c(n).

• But then uniform-cost would have expanded ni+1 not n.

• So every node on this path must already be expanded, i.e., this path has already been expanded. QED

Page 78: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

78Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Search. Proof of Optimality

Lemma 3.

The first time uniform-cost expands a state, it has found the minimal cost path to it (it might later find other paths to the same state but none of them can be less costly).

Proof:• No cheaper path exists, else that path would have been expanded before.

• No cheaper path will be discovered later, as all those paths must be at least as expensive.

• So, when a goal state is expanded the path to it must be optimal.

Page 79: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

79Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Uniform-Cost Properties

Time and Space Complexity?

• O(bC*/ε) where C* is the cost of the optimal solution.

•Difficulty is that there may be many long paths with cost ≤C*; Uniform-cost search must explore them all.

Page 80: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

80Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search

Page 81: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

81Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search

• Place the successors of the current state at the front

of the frontier.

• Expand deepest state first.

Page 82: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

82Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 83: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

83Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 84: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

84Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 85: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

85Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 86: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

86Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 87: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

87Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 88: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

88Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 89: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

89Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 90: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

90Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 91: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

91Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 92: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

92Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 93: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

93Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Search Example

Page 94: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

94Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 95: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

95Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Page 96: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

96Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Properties

Completeness?

• Infinite paths? Cause incompleteness!

• Prune paths with duplicate states?

We get completeness if state space is finite

Optimality? No!

Page 97: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

97Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Properties

Time Complexity?

• O(bm) where m is the length of the longest path in the state

space.

• Very bad if m is much larger than d (lowest depth to a goal

state), but if there are many solution paths it can be much

faster than breadth first.

Page 98: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

98Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-First Properties

• Depth-First Backtrack Points = unexplored siblings of nodes along current path.

• These are the nodes on the frontier.

Space Complexity?

• O(bm), linear space!

•Only explore a single path at a time.

•The frontier only contains the deepest states on the current path along with the backtrack points.

• Only real advantage of DFS

Page 99: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

99Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth-Limited Search

Page 100: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

100Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth Limited Search

• Breadth first has computational, especially, space problems. Depth first can run off down a very long (or infinite) path.

Depth limited search• Perform depth first search but only to a pre-specified depth limit L.

• No node on a path that is more than L steps from the initial state is placed on the Frontier.

• We “truncate” the search by looking only at paths of length L or less.

• Now infinite length paths are not a problem.

• But will only find a solution if a solution of length ≤ L exists.

Page 101: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

101Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth Limited Search

DLS(Frontier, Successors, Goal?)

If Frontier is empty return failure

Curr = select state from Frontier

If(Goal?(Curr)) return Curr.

If Depth(Curr) < LFrontier’ = (Frontier – {Curr}) U Successors(state)

ElseFrontier’ = Frontier – {Curr}CutOffOccured = TRUE.

return DLS(Frontier’, Successors, Goal?)

Page 102: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

102Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Depth Limited Search Example

Page 103: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

103Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search

Page 104: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

104Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search

• Take the idea of depth limited search one step further.

• Starting at depth limit L = 0, we iteratively increase the

depth limit, performing a depth limited search for each

depth limit.

• Stop if no solution is found, or if the depth limited

search failed without cutting off any nodes because of

the depth limit.

Page 105: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

105Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Example

Page 106: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

106Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Example

Page 107: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

107Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Example

Page 108: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

108Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Example

Page 109: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

109Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Properties

Completeness?

• Yes, if a minimal length solution of length d exists. What

happens when the depth limit L=d?

What happens when the depth limit L<d?

Time Complexity?

Page 110: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

110Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Properties

Time Complexity

• (d+1)b0 + db1 + (d-1)b2 + … + bd = O(bd)

• E.g. b=4, d=10

•(11)*40 + 10*41 + 9*42 + … + 2*49 = 815,555

•410 = 1,048,576

•Most nodes lie on bottom layer.

•In fact IDS can be more efficient than breadth first search:

nodes at limit are not expanded. BFS must expand all nodes

until it expand a goal node.

Page 111: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

111Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Beware: BFS can explore more states than IDS

� For IDS, the time complexity is(d+1)b0 + db1 + (d-1)b2 + … + bd = O(bd)

� For BFS, the time complexity is

• 1 + b + b2 + b3 + … + bd-1 + bd + b(bd – 1) = O(bd+1)

E.g. b=4, d=10

� For IDS

• (11)*40 + 10*41 + 9*42 + … + 2*49 = 815,555 (states explored for first 9 limits)

• 410 = 1,048,576 (states explored in last limit)

• Most nodes lie on bottom layer.

� For BFS

• In fact IDS can be more efficient than breadth first search: nodes at limit are

not expanded. BFS must expand all nodes until it expand a goal node.

Page 112: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

112Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Iterative Deepening Search Properties

Space Complexity

• O(bd) Still linear!

Optimal?

• Will find shortest length solution which is optimal if costs are

uniform.

• If costs are not uniform, we can use a “cost” bound instead.

• Only expand paths of cost less than the cost bound.

• Keep track of the minimum cost unexpanded path in each

depth first iteration, increase the cost bound to this on the

next iteration.

• This can be very expensive. Need as many iterations of the

search as there are distinct path costs.

Page 113: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

113Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Path/Cycle Checking

Page 114: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

114Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Path Checking

Recall paths are stored on the frontier (this allows us to

output the solution path).

If <S,n1,…,nk> is a path to node nk, and we expand nk to obtain

child c, we have

<S,n1,…,nk,c>

As the path to “c”.

Path checking:

• Ensure that the state c is not equal to the state reached by any

ancestor of c along this path.

• That is paths are checked in isolation!

Page 115: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

115Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example: Arad to Neamt

Page 116: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

116Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Path Checking Example

Arad Lugoj

Sibiu

R. Vilcea

Timisoara

Arad

Timisoara Mehadia

Arad

Sibiu Craiova

PitestiDrobetaLugoj

Pitesti

R. Vilcea Drobeta

Fagaras

Page 117: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

117Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Cycle Checking

Cycle Checking

• Keep track of all states previously expanded during the search.

• When we expand nk to obtain child c

• Ensure that c is not equal to any previously expanded state.

• This is called cycle checking, or multiple path checking.

• Why can’t we utilize this technique with depth-first search?

• What happens to space complexity?

• Basically the idea of Graph Search (instead of Tree Search

which we considered so far)

Page 118: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

118Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Cycle Checking Example (BFS)

Arad Lugoj

Sibiu

R. Vilcea

Timisoara

Arad

Timisoara Mehadia

Arad

Sibiu Craiova

PitestiDrobetaLugoj

Pitesti

R. Vilcea Drobeta

Fagaras

Page 119: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

119Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Cycle Checking

• High space complexity, only useful with breadth first

search.

• There is an additional issue when we are looking for an

optimal solution

• With uniform-cost search, we still find an optimal solution

• The first time uniform-cost expands a state it has found the

minimal cost path to it.

• This means that the nodes rejected by cycle checking can’t have

better paths.

• We will see later that we don’t always have this property when

we do heuristic search.

Page 120: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

120Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Heuristic Search

(Informed Search)

Page 121: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

121Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Heuristic Search

• In uninformed search, we don’t try to evaluate which

of the nodes on the frontier are most promising. We

never “look-ahead” to the goal.

E.g., in uniform cost search we always expand the cheapest

path. We don’t consider the cost of getting to the goal.

• Often we have some other knowledge about the merit

of nodes, e.g., going the wrong direction in Romania.

Page 122: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

122Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Heuristic Search

Merit of a frontier node: different notions of

merit.

• If we are concerned about the cost of the solution,

we might want a notion of merit of how costly it is

to get to the goal from that search node.

• If we are concerned about minimizing

computation in search we might want a notion of

ease in finding the goal from that search node.

• We will focus on the “cost of solution” notion of

merit.

Page 123: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

123Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Heuristic Search

• The idea is to develop a domain specific heuristic

function h(n).

• h(n) guesses the cost of getting to the goal from node n.

• There are different ways of guessing this cost in different

domains. I.e., heuristics are domain specific.

Page 124: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

124Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Planning a path from Arad to Bucharest, we can utilize the straight line distance

from each city to our goal. This lets us plan our trip by picking cities at each

time point that minimize the distance to our goal (or maximize our heuristic).

Example: Euclidean distance

Page 125: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

125Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Heuristic Search

• Convention: If h(n1) < h(n2) this means that we guess

that it is cheaper to get to the goal from n1 than from n2.

• We require that

• h(n) = 0 for every node n that satisfies the goal.

• Zero cost of getting to a goal node from a goal node.

Page 126: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

126Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Using only h(n): Greedy best-first search

S

n1

n2

n3

Goal

→ step cost = 10

→ step cost = 100

h(n3) = 50h(n1) = 70

(Incomplete)

100

100

10

10

10

• We use h(n) to rank the nodes on the frontier.

• Always expand node with lowest h-value.

• We are greedily trying to achieve a low cost solution.

• However, this method ignores the cost of getting to n, so it can be lead astray

exploring nodes that cost a lot to get to but seem to be close to the goal:

Page 127: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

127Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Greedy best-first search example

Page 128: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

128Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search

• Take into account the cost of getting to the node as well as ourestimate of the cost of getting to the goal from n.

• Define an evaluation function f(n)

f(n) = g(n) + h(n)

• g(n) is the cost of the path to node n

• h(n) is the heuristic estimate of the cost of getting to a goal node from n.

• Always expand the node with lowest f-value on the frontier.

• The f-value is an estimate of the cost of getting to the goal via this node (path).

Page 129: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

129Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 130: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

130Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 131: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

131Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 132: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

132Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 133: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

133Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 134: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

134Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

A* search example

Page 135: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

135Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Properties of A* search depend on conditions on h(n)

• We want to analyze the behavior of the resultant search.

• Completeness, time and space, optimality?

• To obtain such results we must put some further

conditions on the heuristic function h(n) and the search

space.

Page 136: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

136Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Conditions on h(n): Admissible

• We always assume that c(n1→ n2) ≥ ε > 0. The cost of

any transition is greater than zero and can’t be

arbitrarily small.

• Let h*(n) be the cost of an optimal path from n to a

goal node (∞ if there is no path). Then an admissible

heuristic satisfies the condition

h(n) ≤ h*(n)

• an admissible heuristic never over-estimates the cost to reach

the goal, i.e., it is optimistic

• Hence

• h(g) = 0, for any goal node g

• h(n) = ∞ if there is not path from n to a goal node

Page 137: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

137Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consistency (aka monotonicity)

• Is a stronger condition than h(n) ≤ h*(n).

• A monotone/consistent heuristic satisfies the triangle

inequality (for all nodes n1,n2):

h(n1) ≤ c(n1 → n2) + h(n2)

• Note that there might be more than one transition (action)

between n1 and n2, the inequality must hold for all of them.

• Note that monotonicity implies admissibility. Why?

Page 138: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

138Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consistency ���� Admissible

• Assume consistency: h(n) ≤ c(n → n2) + h(n2)

• Prove admissible: h(n) ≤ h*(n)

• Proof by induction that h(n) <=h*(n).

• Base Case: This is trivially true if n2 is a goal state

• Induction Hypothesis: Assume that for any state that is of length L

from a goal, h(n) <=h*(n) is true.

• Induction Step:

• Let node n be length (L+1) from a goal and let n2 be an arbitrary successor of n

• We have h(n) ≤ c(n → n2)+h(n2),

• Thus, h(n) ≤ c(n → n2) + h*(n2) = h*(n) | by IH and because the goal

must be one closer

Page 139: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

139Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Intuition behind admissibility

h(n) ≤ h*(n) means that the search won’t miss any promising paths.

• If it really is cheap to get to a goal via n (i.e., both g(n) and h*(n)

are low), then f(n) = g(n) + h(n) will also be low, and the search

won’t ignore n in favor of more expensive options.

• This can be formalized to show that admissibility implies

optimality.

Page 140: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

140Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Intuition behind monotonicity

h(n1) ≤ c(n1→n2) + h(n2)

• This says something similar, but in addition one

won’t be “locally” mislead. See next example.

Page 141: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

141Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Example: Admissibility without monotonicity

The following h is not consistent since h(n2)>c(n2→n4)+h(n4).

But it is admissible.

S

n1

n3

n2

Goal

→ step cost = 200

→ step cost = 100

{S} → {n1 [200+50=250], n2 [200+100=300]}

→ {n2 [100+200=300], n3 [400+50=450]}

→ {n4 [200+50=250], n3 [400+50=450]}

→ {goal [300+0=300], n3 [400+50=450]}

We do find the optimal path as the heuristic is still admissible. But we are

mislead into ignoring n2 until after we expand n1.

n4

h(n2) = 200

h(n4) = 50

h(n1) =50

h(n3) =50

g(n)+h(n)=f(n)

100

100

100

200

200

200

Page 142: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

142Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Search generated by monotonicity

Inside each contour, the f values are less than or equal to counter value!

• For uniform cost search, bands are “circular”.

• With more accurate heuristics, bands stretch out more toward the goal.

Page 143: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

143Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

1. The f-values of nodes along a path must be non-decreasing.

• Let <Start→ n1→ n2…→ nk> be a path. We claim that

f(ni) ≤ f(ni+1)

• Proof:

f(ni) = c(Start→ …→ ni) + h(ni)

≤ c(Start→ …→ ni) + c(ni→ ni+1) + h(ni+1)

= c(Start→ …→ ni→ ni+1) + h(ni+1)

= g(ni+1) + h(ni+1)

= f(ni+1).

Page 144: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

144Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

2. If n2 is expanded after n1, then f(n1) ≤ f(n2)

(the f-value increases monotonically)

Proof:

• If n2 was on the frontier when n1 was expanded,

then f(n1) ≤ f(n2) otherwise we would have expanded n2.

• If n2 was added to the frontier after n1’s expansion, then let n be an ancestor of n2 that was present when n1 was being expanded (this could be n1 itself). We have f(n1) ≤ f(n) since A* chose n1 while n was present in the frontier. Also, since nis along the path to n2, by property (1) we have f(n)≤f(n2). So, we have f(n1) ≤ f(n2).

Page 145: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

145Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

3. When n is expanded every path with lower f-value has already

been expanded.

• Proof: Assume by contradiction that there exists a path <Start,

n0, n1, ni-1, ni, ni+1, …, nk> with f(nk) < f(n) and ni is its last

expanded node.

• ni+1 must be on the frontier while n is expanded, so

a) by (1) f(ni+1) ≤ f(nk) since they lie along the same path.

b) since f(nk) < f(n) so we have f(ni+1) < f(n)

c) by (2) f(n) ≤ f(ni+1) because n is expanded before ni+1.

• Contradiction from b&c!

Page 146: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

146Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

4. With a monotone heuristic, the first time A* expands a

state, it has found the minimum cost path to that state.

Proof:

• Let PATH1 = <Start, n0, n1, …, nk, n> be the first path to n found.

We have f(path1) = c(PATH1) + h(n).

• Let PATH2 = <Start, m0,m1, …, mj, n> be another path to n found

later. we have f(path2) = c(PATH2) + h(n).

• By property (3), f(path1) ≤ f(path2)

• hence: c(PATH1) ≤ c(PATH2)

Page 147: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

147Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

Complete.

• Yes, consider a least cost path to a goal node

• SolutionPath = <Start→ n1→ …→ G> with cost c(SolutionPath)

• Since each action has a cost ≥ ε > 0, there are only a finite number of paths that have cost ≤ c(SolutionPath).

• All of these paths must be explored before any path of cost > c(SolutionPath).

• So eventually SolutionPath, or some equal cost path to a goal must be expanded.

Time and Space complexity.

• When h(n) = 0, for all n h is monotone.

• A* becomes uniform-cost search!

• It can be shown that when h(n) > 0 for some n, the number of nodes expanded can be no larger than uniform-cost.

• Hence the same bounds as uniform-cost apply. (These are worst case bounds). Still exponential unless we have a very very good h!

• In real world problems, we run out of time and memory! IDA* used to address memory issues.

Page 148: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

148Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Consequences of monotonicity

Optimality

� Yes, by (4) the first path to a goal node must be optimal.

Cycle Checking

� If we do cycle checking (multiple path checking) e.g.

using GraphSearch instead of TreeSearch, it is still

optimal. Because by property (4) we need keep only the

first path to a node, rejecting all subsequent paths.

4. With a monotone heuristic, the first time A* expands a state,

it has found the minimum cost path to that state.

Page 149: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

149Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Admissibility without monotonicity

When “h” is admissible but not monotonic.• Time and Space complexity remain the same. Completeness holds.

• Optimality still holds (without cycle checking), but need a different argument: don’t know that paths are explored in order of cost.

Proof of optimality (without cycle checking):

• Assume the goal path <S,…,G> found by A* has cost bigger than the optimal cost: i.e. C*(G) < f(G).

• There must exists a node n in the optimal path that is still in the frontier.

• We have: f(n)=g(n)+h(n) ≤ g(n)+h*(n)=C*(G) < f(G)

why?

• Therefore, f(n) must have been selected before G by A*. contradiction!

Page 150: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

150Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Admissibility without monotonicity

What about Cycle Checking?• No longer guaranteed we have found an optimal path to a node the first

time we visit it.

• So, cycle checking might not preserve optimality.

• To fix this: for previously visited nodes, must remember cost of

previous path. If new path is cheaper must explore again.

• contours of monotonic heuristics don’t hold.

Page 151: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

151Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Space Problems with A*

• A* has the same potential space problems as BFS

• IDA* - Iterative Deepening A* is similar to Iterative

Deepening Search and similarly addresses space issues.

Page 152: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

152Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

IDA* - Iterative Deepening A*

Objective: reduce memory requirements for A*

• Like iterative deepening, but now the “cutoff” is the f-value (g+h) rather

than the depth

• At each iteration, the cutoff value is the smallest f-value of any node that

exceeded the cutoff on the previous iteration

• Avoids overhead associated with keeping a sorted queue of nodes

• Two new parameters:

• curBound (any node with a bigger f-value is discarded)

• smallestNotExplored (the smallest f-value for discarded nodes in a

round) when frontier becomes empty, the search starts a new

round with this bound.

Page 153: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

153Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Constructing Heuristics

Page 154: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

154Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Building Heuristics: Relaxed Problem

• One useful technique is to consider an easier problem, and let h(n) be the cost of reaching the goal in the easier problem.

• 8-Puzzle moves.

• Can move a tile from square A to B if

• A is adjacent (left, right, above, below) to B

• and B is blank

• Can relax some of these conditions

1. can move from A to B if A is adjacent to B (ignore whether or not position is blank)

2. can move from A to B if B is blank (ignore adjacency)

3. can move from A to B (ignore both conditions).

Page 155: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

155Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Building Heuristics: Relaxed Problem

• #3 “can move from A to B (ignore both conditions)”.

leads to the misplaced tiles heuristic.

• To solve the puzzle, we need to move each tile into its final position.

• Number of moves = number of misplaced tiles.

• Clearly h(n) = number of misplaced tiles ≤ the h*(n) the cost of an optimal sequence of moves from n.

• #1 “can move from A to B if A is adjacent to B (ignore whether or not position is blank)”

leads to the manhattan distance heuristic.

• To solve the puzzle we need to slide each tile into its final position.

• We can move vertically or horizontally.

• Number of moves = sum over all of the tiles of the number of vertical and horizontal slides we need to move that tile into place.

• Again h(n) = sum of the manhattan distances ≤ h*(n)

• in a real solution we need to move each tile at least that that far and we can only move one tile at a time.

Page 156: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

156Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Building Heuristics: Relaxed Problem

The optimal cost to nodes in the relaxed problem is an

admissible heuristic for the original problem!

Proof: the optimal solution in the original problem is a (not

necessarily optimal) solution for relaxed problem, therefore it

must be at least as expensive as the optimal solution in the

relaxed problem.

Page 157: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

157Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Building Heuristics: Relaxed Problem

1,64139,135---24

1135393,473,94114

399347,12710

A*(Manhattan) h2A*(Misplaced) h1IDSDepth

Let h1=Misplaced, h2=Manhattan

• Does h2 always expand fewer nodes than h1?• Yes! Note that h2 dominates h1, i.e. for all n: h1(n)≤h2(n). From

this you can prove h2 is faster than h1.

• Therefore, among several admissible heuristic the one with highest value is the fastest.

Comparison of IDS and A* (average total nodes expanded ):

How does IDS* do?

Page 158: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

158Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Building Heuristics: Pattern databases

• Try to generate admissible heuristics by solving a

subproblem and storing the exact solution cost for that

subproblem

• See Chapter 3.6.3 (not necessary for this course)

Start State Goal State

1

2

3

4

6

8

5

21

3 6

7 8

54

Page 159: CSC384: Introduction to Artificial Intelligencetorsten/csc384-f11/lectures/csc384f11... · 2011-09-22 · Torsten Hahmann, CSC384 Introduction to Artificial Intelligence,University

159Torsten Hahmann, CSC384 Introduction to Artificial Intelligence, University of Toronto, Fall 2011

Local Search

• So far, we keep the paths to the goal.

• For some problems (like 8-queens) we don’t care about the path, we only care about the solution. Many real problem like Scheduling, IC design, and network optimizations are of this form.

• Local search algorithms operate using a single current state and generally move to neighbors of that state.

• There is an objective function that tells the value of each state. The goal has the highest value (global maximum).

• Algorithms like Hill Climbing try to move to a neighbour with the highest value.

• Danger of being stuck in a local maximum. So some randomness is added to “shake” out of local maxima.

• Simulated Annealing: Instead of the best move, take a random move and if it improves the situation then always accept, otherwise accept with a probability <1.

• [If interested read these two algorithms from the R&N book].