I Know general issues include local maxima and plateaus however I am curious if there is any more issues associated to this specific search and what my best course of action would be in order to overcome these issues.
Can someone also give me an example of which sort of problem this search would be good to use for?
Problems with best first search:
There is also an issue with an infinite branch. Assume you are
following a branch where node at depth i
has a heuristic value of
h(v_i) = 2^-i
. You will never get to zero, but greedy best first
will keep developing these nodes.
Example:
2
/ \
/ \
/ \
1 1.5
| |
1/2 1
| |
1/4 0
|
1/8
|
1/16
|
...
Note that the above is admissible heuristic function, but nevertheless best first search will never get the solution, it'll get stuck in the infinite branch.
Solutions:
h(v)
, you chose which node to explore next with f(v) = h(v) + g(v)
(where g(v)
is the "so far cost". The algorithm is complete (finds a solution if one exists) and optimal (finds the "best" solution) if it is given an admissible heuristic function.When to use Best First Search anyway:
h*
in the literature), best first search will find an optimal solution - and fast.f:V->R
instead of on h:V->R
.