forked from s444417/ProjektAI
passing and receiving orders from kitchen
This commit is contained in:
parent
a2e474d520
commit
be49eb4d00
BIN
kelner/images/97734452_672361656930688_396231838525292544_n.jpg
Normal file
BIN
kelner/images/97734452_672361656930688_396231838525292544_n.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 196 KiB |
@ -10,12 +10,12 @@ from kelner.src.managers.WaiterManager import WaiterManager
|
||||
from kelner.src.algorithms.DecisionTree import Tree_Builder
|
||||
|
||||
# create screen consts
|
||||
Scale = 2 # scale for all images used within project
|
||||
CellSize = round(50 * Scale) # pixel size of 1 square cell in the grid
|
||||
PaintOffset = CellSize # pixel size of paint offset for all drawables
|
||||
GridCountX = 15 # number of columns in grid
|
||||
GridCountY = 9 # number of rows in grid
|
||||
ScreenWidth = CellSize * GridCountX + 2 * PaintOffset # screen width in pixels
|
||||
Scale = 2 # scale for all images used within project
|
||||
CellSize = round(50 * Scale) # pixel size of 1 square cell in the grid
|
||||
PaintOffset = CellSize # pixel size of paint offset for all drawables
|
||||
GridCountX = 15 # number of columns in grid
|
||||
GridCountY = 9 # number of rows in grid
|
||||
ScreenWidth = CellSize * GridCountX + 2 * PaintOffset # screen width in pixels
|
||||
ScreenHeight = CellSize * GridCountY + 2 * PaintOffset # screen height in pixels
|
||||
|
||||
# initialize background
|
||||
@ -28,7 +28,7 @@ drawableManager = DrawableCollection()
|
||||
menuManager = MenuManager()
|
||||
|
||||
##TESTING THE DECISION TREE
|
||||
#Testing Data
|
||||
# Testing Data
|
||||
testing_db = [
|
||||
[1, 0, 0, 0, "Kurczak"],
|
||||
[0, 1, 0, 0, "Piwo"],
|
||||
@ -37,10 +37,10 @@ testing_db = [
|
||||
|
||||
]
|
||||
|
||||
#Building a decision tree
|
||||
# Building a decision tree
|
||||
Test_Tree = Tree_Builder.build_tree(testing_db)
|
||||
|
||||
#Testing the tree
|
||||
# Testing the tree
|
||||
if Tree_Builder.zgadnij(testing_db[0], Test_Tree) == "Kurczak":
|
||||
print("test1: passed")
|
||||
else:
|
||||
@ -61,7 +61,6 @@ if Tree_Builder.zgadnij(testing_db[3], Test_Tree) == "Salad":
|
||||
else:
|
||||
print("test4: fail")
|
||||
|
||||
|
||||
# initialize waiter component
|
||||
waiter1 = Waiter(0, 0, 0, GridCountX - 1, 0, GridCountY - 1, CellSize, PaintOffset)
|
||||
# waiter2 = Waiter(0, GridCountY - 1, 0, GridCountX - 1, 0, GridCountY - 1, CellSize, PaintOffset)
|
||||
@ -77,10 +76,10 @@ drawableManager.add(waiter1)
|
||||
|
||||
|
||||
# TODO: create kitchen
|
||||
kitchen = Kitchen(5, GridCountX-5, 5, GridCountY-5, CellSize, PaintOffset)
|
||||
kitchen = Kitchen(5, GridCountX - 5, 5, GridCountY - 5, CellSize, PaintOffset)
|
||||
drawableManager.add(kitchen)
|
||||
|
||||
#My comment
|
||||
# My comment
|
||||
# initialize a number of tables given in range
|
||||
for i in range(0, 40):
|
||||
table = Table(1, GridCountX - 2, 1, GridCountY - 2, CellSize, PaintOffset)
|
||||
|
@ -12,13 +12,28 @@ class Kitchen(Drawable):
|
||||
# call base class constructor
|
||||
super().__init__(14, 0, minX, maxX, minY, maxY, cellSize, offset)
|
||||
self._preparing_orders = []
|
||||
self._ready_orders = []
|
||||
self._ready_orders = None
|
||||
self._photos_path = os.path.join(os.getcwd(), 'foodImages')
|
||||
|
||||
def get_new_orders(self, orders):
|
||||
pass
|
||||
def pass_new_orders(self, orders):
|
||||
for table, order in orders.items():
|
||||
self._preparing_orders.append((table, order))
|
||||
# print("Orders prepared in kitchen: {}".format(self._preparing_orders))
|
||||
|
||||
|
||||
def get_ready_orders(self):
|
||||
if self._ready_orders:
|
||||
out = self._ready_orders[:]
|
||||
self._ready_orders.clear()
|
||||
self._ready_orders = self._preparing_orders
|
||||
return out
|
||||
else:
|
||||
self._ready_orders = self._preparing_orders
|
||||
return []
|
||||
|
||||
def clear_preparing_orders(self):
|
||||
self._preparing_orders.clear()
|
||||
|
||||
def draw(self, screen):
|
||||
xBase = self.getX() * self.getCellSize() + self.getOffset()
|
||||
yBase = self.getY() * self.getCellSize() + self.getOffset()
|
||||
@ -29,5 +44,3 @@ class Kitchen(Drawable):
|
||||
|
||||
def drawAux(self, screen):
|
||||
pass
|
||||
|
||||
|
||||
|
@ -24,6 +24,7 @@ class Table(Drawable):
|
||||
self.__tableLock = Lock()
|
||||
self.__zainteresowania = []
|
||||
|
||||
|
||||
# Build a Decision Tree
|
||||
self.Decision_Tree = Tree_Builder.build_tree(Tree_Builder.training_db)
|
||||
|
||||
@ -68,20 +69,25 @@ class Table(Drawable):
|
||||
# return order
|
||||
|
||||
# waiter collects orders from table
|
||||
def getOrder(self):
|
||||
order = None
|
||||
if self.__tableLock.acquire(False):
|
||||
try:
|
||||
if self.isStatus(Status.Ready) and self.hasOrder():
|
||||
# Generates order
|
||||
order = []
|
||||
for a in range(0,len(self.__guests)):
|
||||
order.append(Tree_Builder.zgadnij(self.__zainteresowania[a], self.Decision_Tree))
|
||||
print("Zamowienie: " + str(order))
|
||||
self.setOrder([])
|
||||
finally:
|
||||
self.__tableLock.release()
|
||||
return order
|
||||
# def getOrder(self):
|
||||
# order = None
|
||||
# if self.__tableLock.acquire(False):
|
||||
# try:
|
||||
# if self.isStatus(Status.Ready) and self.hasOrder():
|
||||
# # Generates order
|
||||
# order = []
|
||||
# for a in range(0,len(self.__guests)):
|
||||
# order.append(Tree_Builder.zgadnij(self.__zainteresowania[a], self.Decision_Tree))
|
||||
# print("Zamowienie: " + str(order))
|
||||
# self.setOrder([])
|
||||
# finally:
|
||||
# self.__tableLock.release()
|
||||
# return order
|
||||
|
||||
def get_order(self):
|
||||
return self.__order
|
||||
|
||||
|
||||
|
||||
#def getOrder(self):
|
||||
# order = None
|
||||
|
@ -131,6 +131,8 @@ class Waiter(Drawable):
|
||||
def get_state(self):
|
||||
return self._ready
|
||||
|
||||
def clear_accepted_orders(self):
|
||||
self.__acceptedOrders.clear()
|
||||
|
||||
|
||||
def draw(self, screen):
|
||||
|
@ -12,6 +12,25 @@ class KitchenManager():
|
||||
def prepare_dish(self):
|
||||
pass
|
||||
|
||||
def receive_orders(self, orders, kitchen):
|
||||
kitchen.get_new_orders(orders)
|
||||
def pass_orders(self, orders, kitchen):
|
||||
kitchen.pass_new_orders(orders)
|
||||
|
||||
def get_ready_orders(self, kitchen):
|
||||
return kitchen.get_ready_orders()
|
||||
|
||||
def draw_orders(self, kitchen):
|
||||
orders_to_print = kitchen.get_ready_orders()
|
||||
dishes = []
|
||||
if orders_to_print:
|
||||
for order in orders_to_print:
|
||||
dishes.append(order[1])
|
||||
print(order[0])
|
||||
|
||||
kitchen.clear_preparing_orders()
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
print(orders_to_print)
|
||||
print(dishes)
|
@ -3,28 +3,13 @@ import random
|
||||
|
||||
# contains all dishes and generates random order for the table
|
||||
class MenuManager:
|
||||
|
||||
# consts, min and max dishes ordered by the people sitting by the same table
|
||||
__MinDishes = 1
|
||||
__MaxDishes = 3
|
||||
|
||||
def __init__(self):
|
||||
self.__menuCard = ["PORK",
|
||||
"FRENCH FRIES",
|
||||
"PIZZA",
|
||||
"CHICKEN",
|
||||
"RIBS",
|
||||
"FISH",
|
||||
"SPAGHETTI",
|
||||
"BEEF",
|
||||
"STEAK",
|
||||
"SALAD",
|
||||
"GRILLED VEGETABLES",
|
||||
"VEAL",
|
||||
"CHOPS",
|
||||
"EMPTY PLATE",
|
||||
"BEER",
|
||||
"CAKE"]
|
||||
self.__menuCard = ['pizza', 'apple_pie', 'donuts', 'sushi', 'omelette', 'nachos', 'tiramisu', 'pho',
|
||||
'carrot_cake', 'mussels', 'waffles', 'hot_dog', 'hamburger']
|
||||
|
||||
# generator
|
||||
def generateOrder(self):
|
||||
@ -33,3 +18,4 @@ class MenuManager:
|
||||
for _ in range(0, count):
|
||||
order += [(self.__menuCard[random.randint(0, len(self.__menuCard) - 1)])]
|
||||
return order
|
||||
|
||||
|
@ -5,7 +5,7 @@ from kelner.src.components.Table import Status
|
||||
|
||||
|
||||
# creates new thread
|
||||
class TableManager (threading.Thread):
|
||||
class TableManager(threading.Thread):
|
||||
|
||||
def __init__(self, drawableManager, menuManager):
|
||||
super().__init__()
|
||||
|
@ -6,8 +6,9 @@ from kelner.src.algorithms.AStar.Finder import Finder
|
||||
from kelner.src.algorithms.BFS.BFS import BFS
|
||||
from kelner.src.managers.KitchenManager import KitchenManager
|
||||
|
||||
|
||||
# creates new thread
|
||||
class WaiterManager (threading.Thread):
|
||||
class WaiterManager(threading.Thread):
|
||||
|
||||
def __init__(self, drawableManager, waiters):
|
||||
super().__init__()
|
||||
@ -16,7 +17,6 @@ class WaiterManager (threading.Thread):
|
||||
self.__runThread = True
|
||||
self._kitchen_manager = KitchenManager(drawableManager)
|
||||
|
||||
|
||||
def __getNearestTargetPath(self, waiter, target):
|
||||
distance = sys.maxsize
|
||||
nearestTargetPath = None
|
||||
@ -27,6 +27,8 @@ class WaiterManager (threading.Thread):
|
||||
origin = (waiter.getX(), waiter.getY())
|
||||
if target == 'kitchen':
|
||||
path = finder.getPath(origin, (14, 1), True)
|
||||
path2 = finder.getPath(origin, (13, 0), True)
|
||||
path = path2 if len(path) > len(path2) else path
|
||||
else:
|
||||
for table in tables:
|
||||
if table.hasOrder():
|
||||
@ -71,12 +73,14 @@ class WaiterManager (threading.Thread):
|
||||
turns = result
|
||||
lessTurnsTable = table
|
||||
|
||||
|
||||
if lessTurnsTable is not None:
|
||||
tables.remove(lessTurnsTable)
|
||||
self.__changeWaiterDirection(waiter, lessTurnsTable.getX(), lessTurnsTable.getY())
|
||||
|
||||
order = lessTurnsTable.getOrder()
|
||||
if order is not None:
|
||||
# order = lessTurnsTable.getOrder()
|
||||
order = lessTurnsTable.get_order()
|
||||
if order is not None and waiter.get_state:
|
||||
waiter.addOrder(lessTurnsTable, order)
|
||||
time.sleep(2)
|
||||
lessTurnsTable.setStatus(Status.Waiting)
|
||||
@ -85,7 +89,22 @@ class WaiterManager (threading.Thread):
|
||||
|
||||
def pass_orders_to_kitchen(self, orders):
|
||||
kitchen = self.__drawableManager.get_kitchen()
|
||||
self._kitchen_manager.receive_orders(orders, kitchen)
|
||||
self._kitchen_manager.pass_orders(orders, kitchen)
|
||||
|
||||
def receive_ready_orders(self, waiter):
|
||||
kitchen = self.__drawableManager.get_kitchen()
|
||||
try:
|
||||
ready_orders = kitchen.get_ready_orders()
|
||||
for dish in ready_orders:
|
||||
print("Orders ready to take", end=" ")
|
||||
print(dish[1])
|
||||
except IndexError as e:
|
||||
print("No orders")
|
||||
waiter.make_ready()
|
||||
waiter.clear_accepted_orders()
|
||||
print("Ready to go")
|
||||
|
||||
|
||||
|
||||
|
||||
# changes the status of a random table from NotReady to Ready
|
||||
@ -109,8 +128,14 @@ class WaiterManager (threading.Thread):
|
||||
self.__moveWaiter(waiter, step[0], step[1])
|
||||
|
||||
if len(waiter.get_current_path()) == 0 and target == 'kitchen':
|
||||
self.pass_orders_to_kitchen(waiter.getAcceptedOrders)
|
||||
print(waiter.getAcceptedOrders())
|
||||
kitchen = self.__drawableManager.get_kitchen()
|
||||
self.pass_orders_to_kitchen(waiter.getAcceptedOrders())
|
||||
# print(waiter.getAcceptedOrders())
|
||||
if self.receive_ready_orders(waiter):
|
||||
self._kitchen_manager.draw_orders(kitchen)
|
||||
|
||||
target = 'table'
|
||||
print(1)
|
||||
else:
|
||||
self.__collectOrder(waiter)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user