2
我試圖實現一個基於維基百科僞碼的簡單A *搜索程序。但是,它對於openset的解釋對我來說還不太清楚。我知道開始節點最初將添加到openset。但是,代碼執行會在remove current from openset
處引發錯誤,這很有意義,因爲current
在第一次迭代期間從未添加到openset。看來openset還需要在循環之前添加起始節點的8個鄰居。有人可以請指點我正確的方向嗎?A *(A Star)算法澄清
感謝,
function A*(start,goal)
closedset := the empty set // The set of nodes already evaluated.
openset := {start} // The set of tentative nodes to be evaluated, initially containing the start node
came_from := the empty map // The map of navigated nodes.
g_score[start] := 0 // Cost from start along best known path.
// Estimated total cost from start to goal through y.
f_score[start] := g_score[start] + heuristic_cost_estimate(start, goal)
while openset is not empty
current := the node in openset having the lowest f_score[] value
if current = goal
return reconstruct_path(came_from, goal)
remove current from openset
add current to closedset
for each neighbor in neighbor_nodes(current)
if neighbor in closedset
continue
tentative_g_score := g_score[current] + dist_between(current,neighbor)
if neighbor not in openset or tentative_g_score <= g_score[neighbor]
came_from[neighbor] := current
g_score[neighbor] := tentative_g_score
f_score[neighbor] := g_score[neighbor] + heuristic_cost_estimate(neighbor, goal)
if neighbor not in openset
add neighbor to openset
return failure
我們有算法處理不一致的啓發式嗎?我四處搜尋,但沒有任何進展。 – GabrielChu