Оновити 'main.py'
This commit is contained in:
parent
e7347a0062
commit
66040a6456
192
main.py
192
main.py
@ -10,7 +10,7 @@ import numpy as np
|
||||
|
||||
pygame.init()
|
||||
|
||||
#ai settings
|
||||
# ai settings
|
||||
S_IDLE = ("kitchen", "middle", "inplace")
|
||||
S_FIRST = ("order", "food")
|
||||
|
||||
@ -21,12 +21,11 @@ HEIGHT = 10
|
||||
WIDTH = 10
|
||||
|
||||
KITCHEN = (1, 1)
|
||||
MIDDLE = (floor(WIDTH/2), floor(HEIGHT/2))
|
||||
MIDDLE = (floor(WIDTH / 2), floor(HEIGHT / 2))
|
||||
|
||||
display = pygame.display.set_mode((WIDTH * 32 + 200, HEIGHT * 32))
|
||||
|
||||
display = pygame.display.set_mode((WIDTH*32+200, HEIGHT*32))
|
||||
|
||||
#eating time
|
||||
# eating time
|
||||
EAT_TIME = 15
|
||||
|
||||
#### Menu
|
||||
@ -38,6 +37,14 @@ menu = Context.fromstring(''' |meat|salad|meal|drink|cold|hot |
|
||||
Pizza | | | X | | | X |''')
|
||||
|
||||
|
||||
#menu.lattice.graphviz()
|
||||
#Digraph.render('Lattice.gv', view=True)
|
||||
|
||||
|
||||
#print(menu.extension(['meal',]))
|
||||
|
||||
###
|
||||
|
||||
#genetic algos
|
||||
gen_num = 20 #generations
|
||||
gen_sol = 6 #solutions
|
||||
@ -46,6 +53,7 @@ gen_par_mating = 2 #how many solutions we select
|
||||
mut_per_gen = 10
|
||||
mut_num_gen = None
|
||||
|
||||
par_selc_type = "tournament"
|
||||
crossover = "two_points"
|
||||
muta_type = "scramble"
|
||||
par_keep = 1 #keep only one parent
|
||||
@ -54,12 +62,12 @@ init_range_l = -2 #low
|
||||
init_range_h = -5 #high
|
||||
|
||||
func_input = ['meal']
|
||||
func_output = []
|
||||
right_output = []
|
||||
|
||||
for e in menu.extension(['meal',]):
|
||||
func_output.append(e)
|
||||
right_output.append(e)
|
||||
|
||||
def fittnes_f(sol):
|
||||
def fitness_f(sol):
|
||||
output = 0
|
||||
if sol in menu.extension([sol],):
|
||||
output = 0.5
|
||||
@ -67,7 +75,27 @@ def fittnes_f(sol):
|
||||
fitness = 1.0 / np.abs(output - r_out)
|
||||
return fitness
|
||||
|
||||
####
|
||||
ga_inst = pygad.GA(num_generations=gen_num,
|
||||
sol_per_pop=gen_sol,
|
||||
num_parents_mating=gen_par_mating,
|
||||
num_genes=len(func_input),
|
||||
fitness_func=fitness_f,
|
||||
mutation_percent_genes=mut_per_gen,
|
||||
mutation_num_genes=mut_num_gen,
|
||||
init_range_low=init_range_l,
|
||||
init_range_high=init_range_l,
|
||||
parent_selection_type=par_selc_type,
|
||||
crossover_type=crossover,
|
||||
mutation_type=muta_type,
|
||||
keep_parents=par_keep,
|
||||
K_tournament=4)
|
||||
|
||||
#ga_inst.run()
|
||||
#ga_inst.plot_result()
|
||||
|
||||
#print(func_output)
|
||||
|
||||
###
|
||||
class Tile:
|
||||
def __init__(self, x, y, canwalk, table, kitchen):
|
||||
self.x = x
|
||||
@ -80,6 +108,8 @@ class Tile:
|
||||
self.visited = False
|
||||
self.path = False
|
||||
self.parent = (0, 0)
|
||||
|
||||
|
||||
class Restaurant:
|
||||
def __init__(self, tables, clients):
|
||||
self.h = HEIGHT
|
||||
@ -92,32 +122,33 @@ class Restaurant:
|
||||
for ih in range(HEIGHT):
|
||||
new = []
|
||||
for iw in range(WIDTH):
|
||||
if ih == 0 or ih == HEIGHT-1 or iw == 0 or iw == WIDTH-1:
|
||||
if ih == 0 or ih == HEIGHT - 1 or iw == 0 or iw == WIDTH - 1:
|
||||
new.append(Tile(ih, iw, False, False, False))
|
||||
else:
|
||||
new.append(Tile(ih, iw, True, False, False))
|
||||
self.tiles.append(new)
|
||||
#random walls
|
||||
# random walls
|
||||
for i in range(3):
|
||||
w = random.randint(1,2)
|
||||
h = random.randint(4,HEIGHT-5)
|
||||
for j in range(random.randint(1,3)):
|
||||
w = random.randint(1, 2)
|
||||
h = random.randint(4, HEIGHT - 5)
|
||||
for j in range(random.randint(1, 3)):
|
||||
ad = self.adjacent(w, h)
|
||||
t = random.choice(ad)
|
||||
w = t.x
|
||||
h = t.y
|
||||
self.tiles[w][h].canwalk = False
|
||||
#random tables
|
||||
# random tables
|
||||
i = 0
|
||||
while i < tables:
|
||||
w = random.randint(2,WIDTH-3)
|
||||
h = random.randint(2,HEIGHT-3)
|
||||
w = random.randint(2, WIDTH - 3)
|
||||
h = random.randint(2, HEIGHT - 3)
|
||||
if not self.tiles[h][w].table and self.tiles[h][w].canwalk:
|
||||
self.tiles[h][w].table = True
|
||||
i = i + 1
|
||||
self.tables.append((w, h))
|
||||
|
||||
self.tiles[1][1].kitchen = True
|
||||
|
||||
def putClient(self):
|
||||
for t in self.tables:
|
||||
if not self.tiles[t[1]][t[0]].clientState:
|
||||
@ -130,17 +161,17 @@ class Restaurant:
|
||||
for ih in range(HEIGHT):
|
||||
for iw in range(WIDTH):
|
||||
self.tiles[ih][iw].visited = False
|
||||
self.tiles[ih][iw].parent = (0,0)
|
||||
self.tiles[ih][iw].parent = (0, 0)
|
||||
|
||||
def adjacent(self, x, y):
|
||||
tiles = []
|
||||
if x == 0 or y == 0 or x == WIDTH or y == HEIGHT:
|
||||
tiles.append(self.tiles[y][x])
|
||||
return tiles
|
||||
tiles.append(self.tiles[y][x-1])
|
||||
tiles.append(self.tiles[y-1][x])
|
||||
tiles.append(self.tiles[y+1][x])
|
||||
tiles.append(self.tiles[y][x+1])
|
||||
tiles.append(self.tiles[y][x - 1])
|
||||
tiles.append(self.tiles[y - 1][x])
|
||||
tiles.append(self.tiles[y + 1][x])
|
||||
tiles.append(self.tiles[y][x + 1])
|
||||
return tiles
|
||||
|
||||
|
||||
@ -149,6 +180,7 @@ def heuristic(a, b):
|
||||
(x2, y2) = b
|
||||
return abs(x1 - x2) + abs(y1 - y2)
|
||||
|
||||
|
||||
class Agent:
|
||||
def __init__(self, x, y):
|
||||
self.x = x
|
||||
@ -157,12 +189,14 @@ class Agent:
|
||||
self.idle = True
|
||||
self.orders = []
|
||||
self.food = False
|
||||
|
||||
def walk(self):
|
||||
t = self.path.pop(0)
|
||||
self.x = t[0]
|
||||
self.y = t[1]
|
||||
if not self.path:
|
||||
self.idle = True
|
||||
|
||||
def BFS(self, goal):
|
||||
restaurant.flush()
|
||||
queue = [(self.x, self.y)]
|
||||
@ -179,10 +213,12 @@ class Agent:
|
||||
x = item.x
|
||||
y = item.y
|
||||
if restaurant.tiles[y][x].canwalk and not restaurant.tiles[y][x].visited:
|
||||
queue.append((x,y))
|
||||
queue.append((x, y))
|
||||
restaurant.tiles[y][x].parent = n
|
||||
|
||||
def wait(self):
|
||||
self.idle = True
|
||||
|
||||
def getTask(self):
|
||||
if waiter.orders:
|
||||
self.BFS(KITCHEN)
|
||||
@ -216,80 +252,80 @@ class Agent:
|
||||
|
||||
|
||||
def drawScreen():
|
||||
pygame.draw.rect(display,(0,0,0), (0, 0, HEIGHT*32, WIDTH*32))
|
||||
pygame.draw.rect(display, (0, 0, 0), (0, 0, HEIGHT * 32, WIDTH * 32))
|
||||
for ih in range(HEIGHT):
|
||||
for iw in range(WIDTH):
|
||||
tile = restaurant.tiles[ih][iw]
|
||||
if tile.canwalk:
|
||||
pygame.draw.rect(display, (128,128,128), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (128, 128, 128), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
if tile.table:
|
||||
if tile.clientState:
|
||||
if tile.clientState == "decide":
|
||||
pygame.draw.rect(display, (0,128,0), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (0, 128, 0), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
elif tile.clientState == "order":
|
||||
pygame.draw.rect(display, (0,255,0), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (0, 255, 0), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
elif tile.clientState == "wait":
|
||||
pygame.draw.rect(display, (255,128,0), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (255, 128, 0), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
elif tile.clientState == "eat":
|
||||
pygame.draw.rect(display, (128,64,0), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (128, 64, 0), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
else:
|
||||
pygame.draw.rect(display, (64,64,64), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.rect(display, (64, 64, 64), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
if tile.kitchen:
|
||||
pygame.draw.rect(display, (255,0,255), (iw * 32 + 1, ih * 32+1, 32-1, 32-1))
|
||||
#if tile.visited:
|
||||
pygame.draw.rect(display, (255, 0, 255), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
# if tile.visited:
|
||||
# pygame.draw.rect(display, (64,0,64), (iw * 32 + 1, ih * 32+1, 14, 14))
|
||||
else:
|
||||
pygame.draw.rect(display, (128,0,128), (iw * 32+1, ih * 32+1, 32-1, 32-1))
|
||||
pygame.draw.circle(display, (255,255,255), (waiter.x*32+16, waiter.y*32+16), 16)
|
||||
pygame.draw.rect(display, (128, 0, 128), (iw * 32 + 1, ih * 32 + 1, 32 - 1, 32 - 1))
|
||||
pygame.draw.circle(display, (255, 255, 255), (waiter.x * 32 + 16, waiter.y * 32 + 16), 16)
|
||||
|
||||
textsurface = font.render(str(restaurant.clients), False, (255,255,255))
|
||||
display.blit(textsurface, (WIDTH*32 + 80, 300))
|
||||
textsurface = font.render(str(restaurant.clients), False, (255, 255, 255))
|
||||
display.blit(textsurface, (WIDTH * 32 + 80, 300))
|
||||
|
||||
pygame.draw.rect(display, (0, 0, 0), (WIDTH * 32 + 80, 332, HEIGHT * 32, WIDTH * 32))
|
||||
textsurface = font.render(str(ticks), False, (255, 255, 255))
|
||||
display.blit(textsurface, (WIDTH * 32 + 80, 332))
|
||||
|
||||
pygame.draw.rect(display,(0,0,0), (WIDTH*32+80, 332, HEIGHT*32, WIDTH*32))
|
||||
textsurface = font.render(str(ticks), False, (255,255,255))
|
||||
display.blit(textsurface, (WIDTH*32 + 80, 332))
|
||||
|
||||
restaurant = Restaurant(3, 5)
|
||||
waiter = Agent(2,2)
|
||||
waiter = Agent(2, 2)
|
||||
clientTime = 10
|
||||
totaltime = 0
|
||||
|
||||
|
||||
clock = pygame.time.Clock()
|
||||
ticks = 0
|
||||
#draw info
|
||||
# draw info
|
||||
help = True
|
||||
if help:
|
||||
font = pygame.font.SysFont('Arial', 18)
|
||||
textsurface = font.render("kelner", False, (255,255,255))
|
||||
pygame.draw.circle(display, (255,255,255), (WIDTH*32 + 26, 16), 16)
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 0))
|
||||
textsurface = font.render("sciana", False, (255,255,255))
|
||||
pygame.draw.rect(display, (128,0,128), (WIDTH*32 + 10, 32, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 32))
|
||||
textsurface = font.render("stolik - pusty", False, (255,255,255))
|
||||
pygame.draw.rect(display, (64,64,64), (WIDTH*32 + 10, 64, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 64))
|
||||
textsurface = font.render("stolik - decyduje", False, (255,255,255))
|
||||
pygame.draw.rect(display, (0,128,0), (WIDTH*32 + 10, 96, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 96))
|
||||
textsurface = font.render("stolik - zamawia", False, (255,255,255))
|
||||
pygame.draw.rect(display, (0,255,0), (WIDTH*32 + 10, 128, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 128))
|
||||
textsurface = font.render("stolik - czeka", False, (255,255,255))
|
||||
pygame.draw.rect(display, (255,128,0), (WIDTH*32 + 10, 160, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 160))
|
||||
textsurface = font.render("stolik - je", False, (255,255,255))
|
||||
pygame.draw.rect(display, (128,64,0), (WIDTH*32 + 10, 192, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 192))
|
||||
textsurface = font.render("kuchnia", False, (255,255,255))
|
||||
pygame.draw.rect(display, (255,0,255), (WIDTH*32 + 10, 224, 32-1, 32-1))
|
||||
display.blit(textsurface, (WIDTH*32 + 50, 224))
|
||||
textsurface = font.render("kelner", False, (255, 255, 255))
|
||||
pygame.draw.circle(display, (255, 255, 255), (WIDTH * 32 + 26, 16), 16)
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 0))
|
||||
textsurface = font.render("sciana", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (128, 0, 128), (WIDTH * 32 + 10, 32, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 32))
|
||||
textsurface = font.render("stolik - pusty", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (64, 64, 64), (WIDTH * 32 + 10, 64, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 64))
|
||||
textsurface = font.render("stolik - decyduje", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (0, 128, 0), (WIDTH * 32 + 10, 96, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 96))
|
||||
textsurface = font.render("stolik - zamawia", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (0, 255, 0), (WIDTH * 32 + 10, 128, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 128))
|
||||
textsurface = font.render("stolik - czeka", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (255, 128, 0), (WIDTH * 32 + 10, 160, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 160))
|
||||
textsurface = font.render("stolik - je", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (128, 64, 0), (WIDTH * 32 + 10, 192, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 192))
|
||||
textsurface = font.render("kuchnia", False, (255, 255, 255))
|
||||
pygame.draw.rect(display, (255, 0, 255), (WIDTH * 32 + 10, 224, 32 - 1, 32 - 1))
|
||||
display.blit(textsurface, (WIDTH * 32 + 50, 224))
|
||||
|
||||
textsurface = font.render("klienci:", False, (255,255,255))
|
||||
display.blit(textsurface, (WIDTH*32 + 20, 300))
|
||||
textsurface = font.render("czas:", False, (255,255,255))
|
||||
display.blit(textsurface, (WIDTH*32 + 20, 332))
|
||||
textsurface = font.render("klienci:", False, (255, 255, 255))
|
||||
display.blit(textsurface, (WIDTH * 32 + 20, 300))
|
||||
textsurface = font.render("czas:", False, (255, 255, 255))
|
||||
display.blit(textsurface, (WIDTH * 32 + 20, 332))
|
||||
|
||||
while True:
|
||||
for event in pygame.event.get():
|
||||
@ -298,7 +334,7 @@ while True:
|
||||
pygame.quit()
|
||||
if event.key == pygame.K_F5:
|
||||
restaurant = Restaurant(3, 5)
|
||||
waiter = Agent(2,2)
|
||||
waiter = Agent(2, 2)
|
||||
clientTime = 10
|
||||
ticks = 0
|
||||
totaltime = 0
|
||||
@ -307,18 +343,17 @@ while True:
|
||||
waiter.BFS(t)
|
||||
if event.key == pygame.K_w:
|
||||
waiter.walk()
|
||||
#update restaurant
|
||||
# update restaurant
|
||||
if restaurant.clients > 0:
|
||||
clientTime = clientTime - 1
|
||||
if clientTime == 0:
|
||||
clientTime = 10
|
||||
restaurant.putClient()
|
||||
for t in restaurant.kitchen:
|
||||
if t[2]> 0:
|
||||
if t[2] > 0:
|
||||
t[2] = t[2] - 1
|
||||
|
||||
|
||||
#update tables
|
||||
# update tables
|
||||
for table in restaurant.tables:
|
||||
if restaurant.tiles[table[1]][table[0]].clientState:
|
||||
if restaurant.tiles[table[1]][table[0]].clientState == "decide":
|
||||
@ -345,15 +380,14 @@ while True:
|
||||
file.write(str(1))
|
||||
file.close()
|
||||
restaurant = Restaurant(3, 5)
|
||||
waiter = Agent(2,2)
|
||||
waiter = Agent(2, 2)
|
||||
clientTime = 10
|
||||
ticks = 0
|
||||
totaltime = 0
|
||||
IDLE = random.choice(S_IDLE)
|
||||
FIRST = random.choice(S_FIRST)
|
||||
|
||||
|
||||
#update waiter
|
||||
# update waiter
|
||||
if waiter.idle:
|
||||
if not waiter.getTask():
|
||||
if not waiter.path:
|
||||
@ -389,7 +423,7 @@ while True:
|
||||
|
||||
if ticks > 1500:
|
||||
restaurant = Restaurant(3, 5)
|
||||
waiter = Agent(2,2)
|
||||
waiter = Agent(2, 2)
|
||||
clientTime = 10
|
||||
ticks = 0
|
||||
totaltime = 0
|
||||
|
Loading…
Reference in New Issue
Block a user