From 904931604937b6bf7c95d06e4f879fb617dc87ae Mon Sep 17 00:00:00 2001 From: Niebby Date: Tue, 13 Apr 2021 15:41:09 +0200 Subject: [PATCH] added BFS based search for finding chests and avoiding creatures --- agent2.py | 45 +++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 43 insertions(+), 2 deletions(-) diff --git a/agent2.py b/agent2.py index be7bfbd..1f58b39 100644 --- a/agent2.py +++ b/agent2.py @@ -114,8 +114,8 @@ class Player(Creature): self.pos, moore=False, include_center=False) - new_position = ( - self.pos[0] + self.directions[self.direction][0], self.pos[1] + self.directions[self.direction][1]) + new_position = (self.pos[0] + self.directions[self.direction][0], + self.pos[1] + self.directions[self.direction][1]) if new_position in possible_steps: self.model.grid.move_agent(self, new_position) @@ -227,10 +227,51 @@ class Player(Creature): # self.weapon3 = chest.loot # chest.loot = buffer + def findShortestPathToTarget(self): + visited = [] + precedessors = {} + queue = [self.pos] + found_target = False + + while queue: + cur_pos = queue.pop(0) + + #check for target + cell_contents = self.model.grid.get_cell_list_contents([cur_pos]) + if cell_contents and any([isinstance(thing, Box) for thing in cell_contents]): + found_target = cur_pos + break + + #enqueue safe unvisited neighbours + neighbours = self.model.grid.get_neighborhood( + cur_pos, + moore=False, + include_center=False) + for cell in neighbours: + #if cell hasn't been visited and the contents don't include creatures + if cell not in visited and not any([isinstance(thing, Creature) for thing in self.model.grid.get_cell_list_contents([cell])]): + queue.append(cell) + precedessors[cell] = cur_pos + + visited.append(cur_pos) + + if found_target: + path = [found_target] + while True: + if path[0] == self.pos: + break + precedessor = precedessors[path[0]] + path.insert(0, precedessor) + return path + + return False + + def step(self): if self.health > 0: self.moveFwd() self.rotate(False) + print(self.findShortestPathToTarget()) cellmates = self.model.grid.get_cell_list_contents([self.pos]) if len(cellmates) > 1: if isinstance(cellmates[0], Box):