2023-05-05 02:56:22 +02:00
|
|
|
from src.obj.Waiter import Waiter
|
|
|
|
import copy
|
|
|
|
|
|
|
|
|
|
|
|
class TemporaryState(Waiter):
|
2023-05-14 14:23:37 +02:00
|
|
|
def __init__(self, parent, cost_so_far, action="blank", cost=0, h=0):
|
2023-05-05 02:56:22 +02:00
|
|
|
super().__init__(copy.deepcopy(parent.position),
|
|
|
|
copy.copy(parent.orientation),
|
|
|
|
copy.copy(parent.square_size),
|
2023-05-14 14:23:37 +02:00
|
|
|
copy.copy(parent.screen_size),
|
2023-05-05 02:56:22 +02:00
|
|
|
copy.copy(parent.basket))
|
2023-05-14 14:23:37 +02:00
|
|
|
self.agent_role = action
|
2023-05-05 02:56:22 +02:00
|
|
|
self.parent = parent
|
|
|
|
self.change_role(action)
|
|
|
|
self.apply_transformation()
|
2023-05-14 14:23:37 +02:00
|
|
|
self.cost = cost
|
|
|
|
self.cost_so_far = cost_so_far
|
|
|
|
self.h = h
|
|
|
|
|
|
|
|
def replace(self, repl):
|
2023-05-14 14:54:04 +02:00
|
|
|
self.cost_so_far = copy.copy(repl.cost_so_far)
|
2023-05-14 14:23:37 +02:00
|
|
|
self.basket = copy.copy(repl.basket)
|
|
|
|
self.parent = repl.parent
|
2023-05-05 02:56:22 +02:00
|
|
|
|
|
|
|
def apply_transformation(self):
|
|
|
|
if self.agent_role == "left":
|
|
|
|
self.orientation = (self.orientation + 1) % 4
|
|
|
|
elif self.agent_role == "right":
|
|
|
|
self.orientation = (self.orientation - 1) % 4
|
|
|
|
elif self.agent_role == "front":
|
|
|
|
if self.orientation % 2: # x (1 or 3)
|
|
|
|
self.position[0] += self.orientation - 2 # x (-1 or +1)
|
|
|
|
else: # y (0 or 2)
|
|
|
|
self.position[1] += self.orientation - 1 # y (-1 or +1)
|
|
|
|
|
|
|
|
def left(self):
|
2023-05-14 14:23:37 +02:00
|
|
|
return TemporaryState(self, self.cost_so_far, "left", 1)
|
2023-05-05 02:56:22 +02:00
|
|
|
|
|
|
|
def right(self):
|
2023-05-14 14:23:37 +02:00
|
|
|
return TemporaryState(self, self.cost_so_far, "right", 1)
|
2023-05-05 02:56:22 +02:00
|
|
|
|
|
|
|
def front(self):
|
2023-05-14 14:23:37 +02:00
|
|
|
return TemporaryState(self, self.cost_so_far, "front", 1)
|
2023-05-05 02:56:22 +02:00
|
|
|
|
|
|
|
def collide_test(self) -> bool:
|
|
|
|
out_of_range = [
|
|
|
|
self.position[0] >= self.square_count,
|
|
|
|
self.position[1] >= self.square_count,
|
|
|
|
self.position[0] < 0,
|
|
|
|
self.position[1] < 0
|
|
|
|
]
|
|
|
|
|
|
|
|
return any(out_of_range)
|
|
|
|
|
|
|
|
def compare(self, state) -> bool:
|
|
|
|
conditions = [
|
|
|
|
self.position == state.position,
|
|
|
|
self.orientation == state.orientation
|
|
|
|
]
|
|
|
|
return all(conditions)
|
2023-05-14 14:23:37 +02:00
|
|
|
|
|
|
|
def change_cost(self, obj):
|
|
|
|
self.cost = 1 # default cost
|
|
|
|
|
|
|
|
if self.agent_role == "front":
|
|
|
|
|
|
|
|
costs = {
|
|
|
|
"kitchen": 5,
|
|
|
|
"table": 5,
|
|
|
|
"order": 20,
|
|
|
|
"wait": 10,
|
|
|
|
"done": 15,
|
|
|
|
}
|
|
|
|
|
|
|
|
if obj.agent_role in costs.keys():
|
|
|
|
self.cost = costs[obj.agent_role]
|
|
|
|
|
|
|
|
def heuristic(self, goal):
|
|
|
|
x = abs(self.position[0] - goal[0])
|
|
|
|
y = abs(self.position[1] - goal[1])
|
|
|
|
|
|
|
|
self.h = x + y
|
|
|
|
|
|
|
|
return self.h
|
|
|
|
|
|
|
|
def current_cost(self):
|
|
|
|
return self.cost_so_far + self.h
|
|
|
|
|
|
|
|
def __eq__(self, __value) -> bool:
|
|
|
|
return self.current_cost() == __value.current_cost()
|
|
|
|
|
|
|
|
def __lt__(self, __value) -> bool:
|
|
|
|
return self.current_cost() < __value.current_cost()
|
|
|
|
|
|
|
|
def __le__(self, __value) -> bool:
|
|
|
|
return self.current_cost() <= __value.current_cost()
|
|
|
|
|
|
|
|
def __gt__(self, __value) -> bool:
|
|
|
|
return self.current_cost() > __value.current_cost()
|
|
|
|
|
|
|
|
def __ge__(self, __value) -> bool:
|
|
|
|
return self.current_cost() >= __value.current_cost()
|