Jump to content

Consistent heuristic: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Explain jargon
No edit summary
Line 1: Line 1:
{{Context|date=October 2009}}
{{Context|date=October 2009}}
In [[computer science]], a '''consistent''' (or '''monotone''') [[heuristic function]] is a strategy for [[Search algorithm|search]] that approaches the solution in an incremental way without taking any step back. Formally, for every node ''N'' and every successor ''P'' of ''N'' generated by any action ''a'', the estimated cost of reaching the goal from ''N'' is no greater than the step cost of getting to ''P'' plus the estimated cost of reaching the goal from ''P''. In other words:
In [[computer science]], a '''consistent''' (or '''monotone''') [[heuristic function]] is a strategy for [[Search algorithm|search]] that approaches the solution in an incremental way without taking any step back. Formally, for every node ''N'' and every [[Successor_(graph_theory)#Direction|successor]] ''P'' of ''N'' generated by any action ''a'', the estimated cost of reaching the goal from ''N'' is no greater than the step cost of getting to ''P'' plus the estimated cost of reaching the goal from ''P''. In other words:
: <math>h(N) \leq c(N,P) + h(P)</math> and
: <math>h(N) \leq c(N,P) + h(P)</math> and
: <math>h(G) = 0.\,</math>
: <math>h(G) = 0.\,</math>

Revision as of 17:18, 24 May 2012

In computer science, a consistent (or monotone) heuristic function is a strategy for search that approaches the solution in an incremental way without taking any step back. Formally, for every node N and every successor P of N generated by any action a, the estimated cost of reaching the goal from N is no greater than the step cost of getting to P plus the estimated cost of reaching the goal from P. In other words:

and

where

  • h is the consistent heuristic function
  • N is any node in the graph
  • P is any child of N
  • G is any goal node.

A consistent heuristic is also admissible, i.e. it never overestimates the cost of reaching the goal. This is proved by induction on , the length of the best path from node to goal. By assumption, , where denotes the cost of the shortest path from n to the goal. Therefore,

,

making it admissible. ( is any node whose best path to the goal, of length m+1, goes through some immediate child whose best path to the goal is of length m.)

Note: not all admissible heuristics are consistent. However, an admissible heuristic , can be made into a consistent heuristic, , through the following adjustment:

(Known as the pathmax[1] equation.)

Consequences of monotonicity

Comparison of an admissible but inconsistent and a consistent heuristic evaluation function.

Consistent heuristics are called monotone because the estimated final cost of a partial solution, is monotonically non-decreasing along the best path to the goal, where is the cost of the best path from start node to . It's necessary and sufficient for a heuristic to obey the triangle inequality in order to be consistent.[2]

In the A* search algorithm, using a consistent heuristic means that once a node is expanded, the cost by which it was reached is the lowest possible, under the same conditions that Dijkstra's algorithm requires in solving the shortest path problem (no negative cost cycles). In fact, if the search graph is given cost for a consistent , then A* is equivalent to best-first search on that graph using Dijkstra's algorithm[1]. In the unusual event that an admissible heuristic is not consistent, a node will need repeated expansion every time a new best (so-far) cost is achieved for it.

References

  1. ^ a b Russell, Stuart (1995). Artificial intelligence: a modern approach. Prentice-Hall. ISBN 0-13-103805-2. {{cite book}}: Unknown parameter |coauthors= ignored (|author= suggested) (help)
  2. ^ Pearl, Judea (1984). Heuristics: Intelligent Search Strategies for Computer Problem Solving. Addison-Wesley. ISBN 0-201-05594-5.
  • CS141 Lecture from Brown University [1]