Working version

This commit is contained in:
Magdalena Wilczyńska 2019-05-14 23:29:19 +02:00
parent b7d463f0ec
commit f358e3c86a
2 changed files with 12 additions and 4 deletions

View File

@ -108,6 +108,12 @@ class GC(Cell):
if(output != None): if(output != None):
[x,y],result,houses_list = output[0], output[1], output[2] [x,y],result,houses_list = output[0], output[1], output[2]
self.moves.extend(result[1:]) self.moves.extend(result[1:])
for i in range(len(dump_list)):
available_movement = check_moves(environment, x, y)
output = BestFS(environment, available_movement, [[x,y]], dump_list)
if(output != None):
[x,y],result,dump_list = output[0], output[1], output[2]
self.moves.extend(result[1:])
self.moves.reverse() self.moves.reverse()
def make_actions_from_list(self,environment): def make_actions_from_list(self,environment):

View File

@ -18,10 +18,6 @@ def BestFS(grid, available_movement, gc_moveset, object_list, depth = 0):
x, y = gc_moveset[-1][0], gc_moveset[-1][1] x, y = gc_moveset[-1][0], gc_moveset[-1][1]
#if depth exceeded, return
if(depth > 15 or len(available_movement) == 0):
return
#calculate distance to the nearest object #calculate distance to the nearest object
min_distance_goal = CalculateDistance([x,y], object_list) min_distance_goal = CalculateDistance([x,y], object_list)
print(depth,min_distance_goal) print(depth,min_distance_goal)
@ -33,6 +29,10 @@ def BestFS(grid, available_movement, gc_moveset, object_list, depth = 0):
object_list.remove([cell,min_distance_goal[0]]) object_list.remove([cell,min_distance_goal[0]])
return([x, y], gc_moveset, object_list) return([x, y], gc_moveset, object_list)
#if depth exceeded, return
if(depth > 15 or len(available_movement) == 0):
return
#set preffered directions based on the closest object #set preffered directions based on the closest object
preffered_directions = [] preffered_directions = []
discouraged_directions = [] discouraged_directions = []
@ -67,6 +67,8 @@ def BestFS(grid, available_movement, gc_moveset, object_list, depth = 0):
print("After sorting: "+str(available_movement)) print("After sorting: "+str(available_movement))
for direction in available_movement: for direction in available_movement:
print("HH")
print(depth,direction)
x_next, y_next = movement(grid,x,y)[0][direction] x_next, y_next = movement(grid,x,y)[0][direction]
available_movement_next = check_moves(grid, x_next,y_next,direction) available_movement_next = check_moves(grid, x_next,y_next,direction)
gc_moveset_next = gc_moveset.copy() gc_moveset_next = gc_moveset.copy()