tsp v3.1
This commit is contained in:
parent
b1d2d04448
commit
4a5676884c
@ -1,8 +1,13 @@
|
|||||||
from data_structures.heap import Heap
|
from data_structures.heap import Heap
|
||||||
from path_search_algorthms import a_star_utils as utils
|
from path_search_algorthms import a_star_utils as utils
|
||||||
|
|
||||||
def search_path(start_x: int, start_y: int, agent_rotation: utils.Rotation, target_x: int, target_y: int, array):
|
|
||||||
|
|
||||||
|
def get_cost(start_x: int, start_y: int, target_x: int, target_y: int, array):
|
||||||
|
actions = search_path(start_x, start_y, utils.Rotation.NONE, target_x, target_y, array)
|
||||||
|
return len(actions)
|
||||||
|
|
||||||
|
|
||||||
|
def search_path(start_x: int, start_y: int, agent_rotation: utils.Rotation, target_x: int, target_y: int, array):
|
||||||
start_node = utils.Node(start_x, start_y, agent_rotation)
|
start_node = utils.Node(start_x, start_y, agent_rotation)
|
||||||
target_node = utils.Node(target_x, target_y, utils.Rotation.NONE)
|
target_node = utils.Node(target_x, target_y, utils.Rotation.NONE)
|
||||||
|
|
||||||
@ -38,51 +43,10 @@ def search_path(start_x: int, start_y: int, agent_rotation: utils.Rotation, targ
|
|||||||
neighbour.h_cost = utils.get_h_cost(neighbour, target_node)
|
neighbour.h_cost = utils.get_h_cost(neighbour, target_node)
|
||||||
neighbour.parent = node
|
neighbour.parent = node
|
||||||
|
|
||||||
# add to search
|
# add to search
|
||||||
if(not search_list.contains(neighbour)):
|
if (not search_list.contains(neighbour)):
|
||||||
search_list.append(neighbour, neighbour.f_cost())
|
search_list.append(neighbour, neighbour.f_cost())
|
||||||
|
|
||||||
# array version
|
|
||||||
|
|
||||||
# nodes for check
|
|
||||||
# search_list = [start_node]
|
|
||||||
|
|
||||||
# checked nodes
|
|
||||||
# searched_list: list[(int, int)] = []
|
|
||||||
|
|
||||||
# while (len(search_list) > 0):
|
|
||||||
# node = search_list[0]
|
|
||||||
|
|
||||||
# # find cheapest node in search_list
|
|
||||||
# for i in range(1, len(search_list)):
|
|
||||||
# if (search_list[i].f_cost() <= node.f_cost()):
|
|
||||||
# if(search_list[i].h_cost < node.h_cost):
|
|
||||||
# node = search_list[i]
|
|
||||||
|
|
||||||
# search_list.remove(node)
|
|
||||||
# searched_list.append((node.x, node.y))
|
|
||||||
|
|
||||||
# # check for target node
|
|
||||||
# if ((node.x, node.y) == (target_x, target_y)):
|
|
||||||
# return trace_path(node)
|
|
||||||
|
|
||||||
# # neightbours processing
|
|
||||||
# neighbours = utils.get_neighbours(node, searched_list, array)
|
|
||||||
# for neighbour in neighbours:
|
|
||||||
|
|
||||||
# # calculate new g cost for neightbour (start -> node -> neightbour)
|
|
||||||
# new_neighbour_cost = node.g_cost + utils.get_neighbour_cost(node, neighbour)
|
|
||||||
|
|
||||||
# if (new_neighbour_cost < neighbour.g_cost or neighbour not in search_list):
|
|
||||||
|
|
||||||
# # replace cost and set parent node
|
|
||||||
# neighbour.g_cost = new_neighbour_cost
|
|
||||||
# neighbour.h_cost = utils.get_h_cost(neighbour, target_node)
|
|
||||||
# neighbour.parent = node
|
|
||||||
|
|
||||||
# # add to search
|
|
||||||
# if(neighbour not in search_list):
|
|
||||||
# search_list.append(neighbour)
|
|
||||||
|
|
||||||
def trace_path(end_node: utils.Node):
|
def trace_path(end_node: utils.Node):
|
||||||
path = []
|
path = []
|
||||||
@ -91,9 +55,11 @@ def trace_path(end_node: utils.Node):
|
|||||||
# set final rotation of end_node because we don't do it before
|
# set final rotation of end_node because we don't do it before
|
||||||
node.rotation = utils.get_needed_rotation(node.parent, node)
|
node.rotation = utils.get_needed_rotation(node.parent, node)
|
||||||
|
|
||||||
while (node.parent != 0):
|
while (node.parent != False):
|
||||||
move = utils.get_move(node.parent, node)
|
if (node.parent == utils.Rotation.NONE):
|
||||||
path += move
|
path += "forward"
|
||||||
|
else:
|
||||||
|
path += utils.get_move(node.parent, node)
|
||||||
node = node.parent
|
node = node.parent
|
||||||
|
|
||||||
# delete move on initial tile
|
# delete move on initial tile
|
||||||
@ -106,7 +72,3 @@ def trace_path(end_node: utils.Node):
|
|||||||
path.append("forward")
|
path.append("forward")
|
||||||
|
|
||||||
return path
|
return path
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user