2023-05-05 02:56:22 +02:00
|
|
|
import copy
|
|
|
|
from src.obj.Object import Object
|
|
|
|
|
|
|
|
|
|
|
|
class Waiter(Object):
|
2023-05-26 03:02:16 +02:00
|
|
|
def __init__(self, position, orientation, square_size, screen_size, basket=[], memory=[], battery=300):
|
2023-05-14 14:23:37 +02:00
|
|
|
super().__init__("waiter", position, orientation, square_size, screen_size)
|
2023-05-26 03:02:16 +02:00
|
|
|
self.battery = battery
|
|
|
|
self.basket_size = 4
|
|
|
|
self.memory_size = 4
|
2023-05-05 02:56:22 +02:00
|
|
|
self.basket = basket
|
2023-05-26 03:02:16 +02:00
|
|
|
self.memory = memory
|
2023-05-05 02:56:22 +02:00
|
|
|
self.prev_position = copy.deepcopy(self.position)
|
|
|
|
self.prev_orientation = copy.copy(self.orientation)
|
|
|
|
|
2023-05-14 14:23:37 +02:00
|
|
|
def changeState(self, state):
|
|
|
|
self.position = copy.deepcopy(state.position)
|
|
|
|
self.orientation = copy.copy(state.orientation)
|
|
|
|
self.basket = copy.copy(state.basket)
|
2023-05-26 03:02:16 +02:00
|
|
|
self.battery -= state.cost
|
2023-05-14 14:23:37 +02:00
|
|
|
return state
|
|
|
|
|
2023-05-26 03:02:16 +02:00
|
|
|
def dish_in_basket(self, table) -> bool:
|
|
|
|
return table in self.basket
|
2023-05-14 14:23:37 +02:00
|
|
|
|
2023-05-26 03:02:16 +02:00
|
|
|
def basket_is_full(self) -> bool:
|
|
|
|
return self.basket_size == 0
|
|
|
|
|
2023-06-01 17:45:01 +02:00
|
|
|
def basket_is_empty(self) -> bool:
|
|
|
|
return self.basket_size == 4
|
|
|
|
|
|
|
|
def combine_orders(self, current_time):
|
2023-05-26 03:02:16 +02:00
|
|
|
while not self.basket_is_full() and not self.memory_is_empty():
|
|
|
|
dish = self.memory.pop()
|
2023-06-01 17:45:01 +02:00
|
|
|
dish.set_done(current_time)
|
2023-05-26 03:02:16 +02:00
|
|
|
self.basket.append(dish)
|
|
|
|
self.basket_size -= 1
|
|
|
|
self.memory_size += 1
|
|
|
|
|
2023-06-01 17:45:01 +02:00
|
|
|
def deliver_dish(self, table, current_time):
|
2023-05-26 03:02:16 +02:00
|
|
|
if table in self.basket:
|
2023-06-01 17:45:01 +02:00
|
|
|
table.reset(current_time)
|
2023-05-26 03:02:16 +02:00
|
|
|
self.basket.remove(table)
|
|
|
|
self.basket_size += 1
|
|
|
|
|
|
|
|
def order_in_memory(self, table) -> bool:
|
|
|
|
return table in self.memory
|
2023-05-05 02:56:22 +02:00
|
|
|
|
2023-05-26 03:02:16 +02:00
|
|
|
def memory_is_empty(self) -> bool:
|
|
|
|
return not self.memory
|
2023-05-05 02:56:22 +02:00
|
|
|
|
2023-05-26 03:02:16 +02:00
|
|
|
def memory_is_full(self) -> bool:
|
|
|
|
return self.memory_size == 0
|
|
|
|
|
2023-06-01 17:45:01 +02:00
|
|
|
def collect_order(self, table, current_time):
|
2023-05-26 03:02:16 +02:00
|
|
|
if self.memory_is_full():
|
|
|
|
return
|
|
|
|
if table.agent_role == "order":
|
2023-06-01 17:45:01 +02:00
|
|
|
table.set_wait(current_time)
|
2023-05-26 03:02:16 +02:00
|
|
|
self.memory.append(table)
|
|
|
|
self.memory_size -= 1
|
|
|
|
|
2023-06-01 17:45:01 +02:00
|
|
|
def battery_status(self) -> int:
|
|
|
|
return 1 if self.battery >= 100 else 0
|
2023-05-26 03:02:16 +02:00
|
|
|
|
|
|
|
def recharge(self):
|
|
|
|
self.battery = 300
|
2023-05-05 02:56:22 +02:00
|
|
|
|
|
|
|
def left(self):
|
|
|
|
self.orientation = (self.orientation + 1) % 4
|
|
|
|
|
|
|
|
def right(self):
|
|
|
|
self.orientation = (self.orientation - 1) % 4
|
|
|
|
|
|
|
|
def front(self):
|
|
|
|
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)
|
2023-06-01 17:45:01 +02:00
|
|
|
|
|
|
|
def chechNeighbor(self, n, r=1):
|
|
|
|
|
|
|
|
cond_x = abs(self.position[0] - n.position[0]) <= r
|
|
|
|
cond_y = abs(self.position[1] - n.position[1]) <= r
|
|
|
|
|
|
|
|
return cond_x and cond_y
|