From acafb05ae0d1422cad6d220fb1366c563691ccb9 Mon Sep 17 00:00:00 2001 From: Kacper Date: Thu, 15 Jun 2023 14:03:24 +0200 Subject: [PATCH] small fix + pygad install --- NN/Generator.py | 2 - NN/trainer.py | 11 +- astar.py | 32 ++--- bfs.py | 18 +-- board.py | 10 +- cart.py | 2 - classes.py | 15 +- decisionTree/generator.py | 4 +- decisionTree/treemaker.py | 10 +- definitions.py | 4 +- img/player.png | Bin 16754 -> 2988 bytes img/tree.png | Bin 2079 -> 3959 bytes main.py | 295 ++++++++++---------------------------- screen.py | 2 +- 14 files changed, 120 insertions(+), 285 deletions(-) diff --git a/NN/Generator.py b/NN/Generator.py index cc54c28..7e28fe6 100644 --- a/NN/Generator.py +++ b/NN/Generator.py @@ -15,7 +15,6 @@ b = [Image.open("b1.png").convert('RGBA'), Image.open("b2.png").convert('RGBA'), def generate(water, fertilizer, plantf): - new_im = None if water == 1: new_im = Image.new('RGB', (100, 100), (160 + random.randint(-10, 10), 80 + random.randint(-10, 10), 40 + random.randint(-10, 10))) @@ -81,4 +80,3 @@ for x in range(0, 1000): generate(0, 1, random.randint(0, 2)).save('datasets/01/' + str(x) + '.png') for x in range(0, 1000): generate(1, 1, random.randint(0, 2)).save('datasets/11/' + str(x) + '.png') - diff --git a/NN/trainer.py b/NN/trainer.py index f27083b..845ab43 100644 --- a/NN/trainer.py +++ b/NN/trainer.py @@ -2,13 +2,14 @@ import pathlib import random import torch -from PIL.Image import Image from torch import nn from torch.utils.data import DataLoader from torchvision import datasets, transforms from torchvision.transforms import Lambda -device = torch.device('cuda') + +device = torch.device('cpu') + def train(model, dataset, n_iter=100, batch_size=2560000): optimizer = torch.optim.SGD(model.parameters(), lr=0.01) @@ -40,8 +41,8 @@ train_data = datasets.ImageFolder(root="./datasets", transform=data_transform, target_transform=None) -model1=nn.Sequential(nn.Linear(30000, 10000),nn.ReLU(),nn.Linear(10000,10000),nn.ReLU(),nn.Linear(10000,10000),nn.Linear(10000,4),nn.LogSoftmax(dim=-1)).to(device) +model1 = nn.Sequential(nn.Linear(30000, 10000), nn.ReLU(), nn.Linear(10000, 10000), nn.ReLU(), nn.Linear(10000, 0000), nn.Linear(10000, 4), nn.LogSoftmax(dim=-1)).to(device) model1.load_state_dict(torch.load("./trained")) -train(model1,train_data) +train(model1, train_data) -torch.save(model1.state_dict(), "./trained") \ No newline at end of file +torch.save(model1.state_dict(), "./trained") diff --git a/astar.py b/astar.py index 655b25a..41136a2 100644 --- a/astar.py +++ b/astar.py @@ -1,7 +1,6 @@ from operator import itemgetter import cart import copy -from classes import Field class Istate: @@ -68,23 +67,23 @@ class Node: self.y = y -def fieldCost(T,node): +def fieldCost(T, node): c = 0 if T[node.x-1][node.y-1].plantType == 1: - c =2 + c = 2 elif T[node.x-1][node.y-1].plantType == 2: - c =5 + c = 5 elif T[node.x-1][node.y-1].plantType == 3: - c =13 + c = 13 elif T[node.x-1][node.y-1].plantType == 4: - c =100000 + c = 100000 else: - c=0 + c = 0 if T[node.x-1][node.y-1].isWet == 1: c = c + 4 else: - c=c+1 + c = c+1 return c @@ -92,7 +91,7 @@ def fieldCost(T,node): def cost(T, node): cost = 0 - while (node.get_parent() != None): + while node.get_parent() is not None: cost = cost + fieldCost(T, node) node = node.get_parent() @@ -103,7 +102,7 @@ def f(goaltest, map, node): return cost(map, node) + heuristic(goaltest, node) -def goal_test(elem,goaltest): +def goal_test(elem, goaltest): if elem.get_x() == goaltest[0] and elem.get_y() == goaltest[1]: return True else: @@ -132,7 +131,7 @@ def graphsearch(explored, f, fringe, goaltest, istate, map, succ): # przeszukiw explored_tuple.append((x.get_direction(), x.get_x(), x.get_y())) x = Node(action, state[0], elem[0], state[1], state[2]) # stworzenie nowego wierzchoÅ‚ka, którego rodzicem jest elem p = f(goaltest, map, x) # liczy priorytet - #print('Koszt =', p) + # print('Koszt =', p) if state not in fringe_tuple and state not in explored_tuple: # jeżeli stan nie znajduje siÄ™ na fringe oraz nie znajduje siÄ™ w liÅ›cie wierzchoÅ‚ków odwiedzonych fringe.append((x, p)) # dodanie wierzchoÅ‚ka na fringe fringe = sorted(fringe, key=itemgetter(1)) # sortowanie fringe'a wedÅ‚ug priorytetu @@ -141,7 +140,7 @@ def graphsearch(explored, f, fringe, goaltest, istate, map, succ): # przeszukiw for (state_prio, r) in fringe_tuple_prio: if str(state_prio) == str(state): if r > p: - fringe.insert(i, (x,p)) # zamiana state, który należy do fringe z priorytetem r na state z priorytetem p (niższym) + fringe.insert(i, (x, p)) # zamiana state, który należy do fringe z priorytetem r na state z priorytetem p (niższym) fringe.pop(i + 1) fringe = sorted(fringe, key=itemgetter(1)) # sortowanie fringe'a wedÅ‚ug priorytetu break @@ -154,7 +153,7 @@ def heuristic(goaltest, node): def print_moves(elem): moves_list = [] - while (elem.get_parent() != None): + while elem.get_parent() is not None: moves_list.append(elem.get_action()) elem = elem.get_parent() moves_list.reverse() @@ -184,7 +183,6 @@ def succ(elem): temp_move_east = elem.get_x() + 1 temp_move_north = elem.get_y() + 1 - if cart.Cart.is_move_allowed_succ(elem) == "x + 1": actions_list.append(("move", (elem.get_direction(), temp_move_east, elem.get_y()))) elif cart.Cart.is_move_allowed_succ(elem) == "y + 1": @@ -194,8 +192,4 @@ def succ(elem): elif cart.Cart.is_move_allowed_succ(elem) == "x - 1": actions_list.append(("move", (elem.get_direction(), temp_move_west, elem.get_y()))) - - - - - return actions_list \ No newline at end of file + return actions_list diff --git a/bfs.py b/bfs.py index 0f15cc8..d32614a 100644 --- a/bfs.py +++ b/bfs.py @@ -1,4 +1,3 @@ -import sys import cart import copy @@ -67,23 +66,19 @@ class Node: self.y = y -def goal_test(goaltest,elem): +def goal_test(goaltest, elem): if elem.get_x() == goaltest[0] and elem.get_y() == goaltest[1]: return True else: return False -# def graphsearch(explored, fringe, goaltest, istate, succ): # przeszukiwanie grafu wszerz -def graphsearch(explored, fringe, goaltest, istate): # przeszukiwanie grafu wszerz +def graphsearch(goaltest, istate): # przeszukiwanie grafu wszerz node = Node(None, istate.get_direction(), None, istate.get_x(), istate.get_y()) fringe = [] - #elem = [] explored = [] - #action = [] fringe.append(node) # wierzchoÅ‚ki do odwiedzenia - # fringe = [node] while True: if not fringe: return False @@ -109,7 +104,7 @@ def graphsearch(explored, fringe, goaltest, istate): # przeszukiwanie grafu wsz def print_moves(elem): moves_list = [] - while (elem.get_parent() != None): + while elem.get_parent() is not None: moves_list.append(elem.get_action()) elem = elem.get_parent() moves_list.reverse() @@ -139,7 +134,6 @@ def succ(elem): temp_move_east = elem.get_x() + 1 temp_move_north = elem.get_y() + 1 - if cart.Cart.is_move_allowed_succ(elem) == "x + 1": actions_list.append(("move", (elem.get_direction(), temp_move_east, elem.get_y()))) elif cart.Cart.is_move_allowed_succ(elem) == "y + 1": @@ -149,8 +143,4 @@ def succ(elem): elif cart.Cart.is_move_allowed_succ(elem) == "x - 1": actions_list.append(("move", (elem.get_direction(), temp_move_west, elem.get_y()))) - - - - - return actions_list \ No newline at end of file + return actions_list diff --git a/board.py b/board.py index 30cd4b9..66de6d9 100644 --- a/board.py +++ b/board.py @@ -1,6 +1,5 @@ import pygame from screen import SCREEN -global BLACK # global SCREEN global BLACK @@ -8,9 +7,9 @@ global gridObjects global imgTree global imgTree imgTree = pygame.image.load('img/tree.png') - gridObjects = {} # Store grid-box objects from Grid Class + class Grid(object): # ta klasa rysuje kratÄ™ na ekranie def __init__(self, x, y, sx, sy): @@ -27,6 +26,7 @@ class Grid(object): BLACK = (0, 0, 0) pygame.draw.rect(SCREEN, BLACK, (self.x, self.y, self.sx, self.sy), self.width) + class Box(object): # global SCREEN @@ -43,6 +43,7 @@ class Box(object): # global BLACK pygame.draw.rect(SCREEN, self.color, pygame.Rect(self.x, self.y, self.sx, self.sy)) + class Obstacle(object): def __init__(self, mouseObj): self.mseX = mouseObj[0] @@ -66,6 +67,7 @@ class Obstacle(object): SCREEN.blit(imgTree, (self.posX, self.posY)) # pygame.display.update() + def getGridBoxes(grid_box): - global gridObjects - return gridObjects[grid_box] \ No newline at end of file + global gridObjects + return gridObjects[grid_box] diff --git a/cart.py b/cart.py index 6fa4774..2e2dd93 100644 --- a/cart.py +++ b/cart.py @@ -25,7 +25,6 @@ class Cart: def set_y(self, y): self.y = y - def is_move_allowed(self, cart_rect): # sprawdza czy dany ruch, który chce wykonać wózek jest możliwy, zwraca prawdÄ™ lub faÅ‚sz if self.direction == definitions.CART_DIRECTION_EAST and cart_rect.x + definitions.BLOCK_SIZE < definitions.WIDTH_MAP: @@ -74,4 +73,3 @@ class Cart: self.direction = 1 else: self.direction = self.direction + 1 - diff --git a/classes.py b/classes.py index 741efe8..a95f3c4 100644 --- a/classes.py +++ b/classes.py @@ -1,11 +1,12 @@ class Field: def __init__(self, fieldType, plantType, isWet, wetTime, isFertilized, fertilizedTime): - self.fieldType =fieldType # good/bad - self.plantType =plantType # wheat/carrot/cabbage - self.isWet =isWet # yes/no - self.wetTime =wetTime # number - self.isFertilized =isFertilized # yes/no - self.fertilizedTime =fertilizedTime # number + self.fieldType = fieldType # good/bad + self.plantType = plantType # wheat/carrot/cabbage + self.isWet = isWet # yes/no + self.wetTime = wetTime # number + self.isFertilized = isFertilized # yes/no + self.fertilizedTime = fertilizedTime # number + class Plant: def __init__(self, plantType, growthState): @@ -21,4 +22,4 @@ class Fertilizer: class Player: x = 0 y = 0 - rotation = 0 \ No newline at end of file + rotation = 0 diff --git a/decisionTree/generator.py b/decisionTree/generator.py index 9681fe1..3954ac1 100644 --- a/decisionTree/generator.py +++ b/decisionTree/generator.py @@ -1,5 +1,6 @@ import random + # Generowanie unikalnej losowej linii tekstu def generate_unique_line(existing_lines): while True: @@ -9,6 +10,7 @@ def generate_unique_line(existing_lines): if line not in existing_lines: return line + # Generowanie 200 unikalnych linii tekstu lines = [] while len(lines) < 200: @@ -18,4 +20,4 @@ while len(lines) < 200: # Zapisywanie linii tekstu do pliku with open('decisionTree/database.txt', 'w') as file: for line in lines: - file.write(line + '\n') \ No newline at end of file + file.write(line + '\n') diff --git a/decisionTree/treemaker.py b/decisionTree/treemaker.py index 679930e..1c8d1c0 100644 --- a/decisionTree/treemaker.py +++ b/decisionTree/treemaker.py @@ -1,6 +1,4 @@ - - -#from sklearn.datasets import load_iris +# from sklearn.datasets import load_iris from sklearn.tree import export_text from sklearn.tree import DecisionTreeClassifier @@ -52,14 +50,14 @@ with open("decisionTree/database.txt", 'r') as f: view.append(x) X1.append(test_list) -f = open("decisionTree/learning_set.txt", "w") #zapisuje atrybuty s³ownie +f = open("decisionTree/learning_set.txt", "w") # zapisuje atrybuty s³ownie for i in view: f.write(str(i)+"\n") f.close() Y1 = [] -with open("decisionTree/decissions.txt", 'r') as f: #czyta decyzje +with open("decisionTree/decissions.txt", 'r') as f: # czyta decyzje for line in f: line = line.strip() test = int(line) @@ -67,7 +65,7 @@ with open("decisionTree/decissions.txt", 'r') as f: #czyta decyzje dataset = X1 decision = Y1 -labels = ['Rain','Plant','Temperature','Sun','Snow','Moisture','Rotten','Time'] +labels = ['Rain', 'Plant', 'Temperature', 'Sun', 'Snow', 'Moisture', 'Rotten', 'Time'] model = DecisionTreeClassifier(random_state=0, max_depth=20).fit(dataset, decision) filename = 'decisionTree/decisionTree.sav' print("Model trained") diff --git a/definitions.py b/definitions.py index af5ddd9..aabf9e8 100644 --- a/definitions.py +++ b/definitions.py @@ -1,5 +1,3 @@ -# definicje -import os import pygame pygame.init() @@ -21,4 +19,4 @@ HEIGHT_AMOUNT, WIDTH_AMOUNT = 11, 11 HEIGHT_MAP, WIDTH_MAP = BLOCK_SIZE * HEIGHT_AMOUNT, BLOCK_SIZE * WIDTH_AMOUNT HEIGHT, WIDTH = HEIGHT_MAP + BLOCK_SIZE, WIDTH_MAP IMAGE_SIZE_NEURAL_NETWORK = 16 -WINDOW = pygame.display.set_mode((WIDTH, HEIGHT)) \ No newline at end of file +WINDOW = pygame.display.set_mode((WIDTH, HEIGHT)) diff --git a/img/player.png b/img/player.png index 06176385e039fdf126fbbb8792bb93c3082c2061..a68aa644d83f9bf9df1e177930e961c78afa4195 100644 GIT binary patch delta 2951 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 literal 16754 zcmeHtWmFv9((d5y8gv*m1R31j-7UBb?(XgccXtWyuE7%|c#z;uAP`&vm%K;5bJqR- zoVD)#cY0R$bnjjD?5d|~@9v(dC}l+{G-M)V004j{BQ37_`px>fQzF8@9v545;sF3! zV{dhBS5;#Vprf;cxs@#h=<4MN0YW^j%mDz;mC_uYG`+UkvJIYSBIrkRZYq&l4YrD{ zrCT--L}wIZ^j0>F74J<0G4vfV=IYr~-;2-pm#rm4!A`yRb;X*~b^N~~lN~x=p0a-a z+`N2z{4IO&*mQooq%XfgE^aV;yAg2v;P*0pvb6*yXh^e>x`94_dy8=LQ;6{1=jnMg zs8=h+RpMd27lG(;iMo$G^e5E*L8~um&u@Q}6W?Bcp%)$aXYSvrj~mR7LeJl|1>WV* z4tuIf=k=*Q7zoei@6PUK4{cCr^d#1Kmv(E7+!`^A3DwNi8Fo+W>svpMa{Xqc@9TY} ze1Aera%<7-{M1YRyJ75lX(_<>d)Tj0jM=)&(T(Yx$J?&E+oieK3m1ui>fYxyo8P@Y z`%LDw3~s;I=cgHae|m0gaBhbRVO=C|1`Hjxi%AQoJD1M9Lqj<5@66&$C)#hVylCuo$ z5E~Q%C-|!_pex`p$VUU2!je(T+h%x!#k!#bRYEb~k`sh|=ArUMcQbz@;8|4<2aDl7 zBz4TlcD!v0URa94r5jdXrEeX3_)CMv086ZqVipy|tn6S-KY4Z^LD&JE?pG=ZvDxIH| zWiFn`vaT&%T&WaxYMpPiDP356?@&CM=Y3YXwC?@0cp6Izn*B>fajf7-MzV`y9RK~* zE}Bbi`|Rhcb`33EzgP~gqozxyuCvxhGN1R&W}6WjHj8%O__q>dY4e?rt;+MA_Nf=_ zow+ugPwd(@oDS+L{01M$`(7mGKXF-KNXR zJ3W?HWLjE2D)Cezw^VEb!HZ`fa$hzp^XvHD+h_YI+BZ5L&}6K_02j(?lvyoojh7}` z@2Ex1UbTU_ai@;K^;N+6Dq)J$kteDrT_GO^~gVdBCEb!G{n38KSD zcHywvv*j<_Yg?6b$}PJ@?0(?L_xY(<;gS#Hgzj}$!e6R|{;jFD)v9yGcaZrJO56)` zD=Fn&&G6|YDSEy)cRC_QU+3QYPbYnJcgHJI_*NoS8`&6B63 zqk?vIJ?K?$W{F6GY*2!JteD36^S&EB)!|P^RyL1!yI;dxoe&HCD&?yp-YcXlkc;%i zC5a8;4N}$!zd3d07;mqmL+<&9nO1bdrkZ(eJ}p)q-TvKg#O(bWOtK(39cz%ue#YBJhjn zJ}xg&S9#dq^1h9<;_*8Z=;kIF{9bp_vp~5ZO0+h${8>H@igNH5nBF%^9ca!8aVk7&gWn-lqD9TPtZ$ zi63oCl;LjOw2~UnoID-$I$%Jdzc{x=By`+j)SSb8OnGAtbxx{OJE-+*bGU*SwpO%T z*0VndbM}L-Cad)B*^ynZn)MlI<50%j1Unpjg=`-Qbwttk`82g{G=J4%tx2e69=M-u z+fd#mb0vi{Ew6=T2@ic^N-?qhT>`OV3RoZ2+7W27ql9!s^2(0QTbpNIpwePS%-M5JG)Lw8OHu%J`(cJhtEiKXmBeGj0}|5ja3E)6EaA{KQE~ zGcrH+!ztF#UmigH-9+%2$JxWoiZN4od2bPYT2I4(Tq;jETIF-3(^fG!JYB`)R4QX=xrz)N^>e{n0jcd?Y_~B1$=U%9$*?fBdH>}7&%3rir#vcPE=;H*vWuSJkX3gLV6aO>HOC{@fad8Z(E&fla zxv4z;H_FOAMxF@y!kOYM^;yN39vW6H@6^(W_`Xtjgt@E*_zNi8oe7P z80!fWZ0rP6AaBCKmjNJF)^Ic;3hknoOh#SMx-1U%XIRSg=T@a^B*KLIWD=i>vRlHS zMh1hB`;=o*7+e%soGhwECX2;$aA5x66q>P+DIsKU5HR|2=b}=(bfRy)fc)iI%)VIE zxvf7Z^B6&wGZPt^G-JZQ?j{_>8WN4OzLU*~vsOz8=nVpck~jKlC4BY20D|IBlC^}7!NmDT{PUC z?>@F5WJ;T@=YOoqVct7NT-Sh*A6KhP`?ax*yRW50#1A~R77nlWqr9K1TLN8QgGy)Bt;V2xoY4O{~$=`juhDxo&qfB3O3fM$K;ojjT#Qmm# zsSXU#l!tcy06kFlZEW3O=&Tyg@g@U5x6R>=rF1ud_g>I)Q$zKH3S)z_>WH7duLAUK z1E0W_U`vw7Ho+StIiPaIzD$Qn#925`k@6yiAIimO4q@;o!#~-? zq~zlc=^Qc=g%K9Cau++G3lKXGLQ*%wG`2XCN{w7p4CGFW8Wz?HB9$%cb+h6?mEGyG z)NJF_(nHK+cE!cTq_Ba_sIs;RgKs7gr-~ZrL6SycFd*jnfCgn96c@G$R*eypOCgv?Aa9g|*5885;EM1YYj<1YQm}18V0FGmKG>J8IgZ@(H!_{iV`gZ#C@b}$(;=ab0xw3DqVjcQh2WJDWNAL znq4e~)n#-(5{H)qM7I!mo5H$;1}Z2ov3}dC;9FmAxz1t@v(|*l%MntluM>Jz?)G%= zomd6y#)ZIwdzACg+$TfptU>E-5a99noeFD%Er5aUD!(n&8sFnnZ z7JTzuLc9C;#z}v9*UqSj}Y+*Tk#{_Mp_3l*!a4^DG;1*ZdFy( zEUsAbBJx0qtXT~D%4J4Z9pbGU5xoOyfA3kj)5t@L4)bPY;pS}s)QTbNDzqFaLPp@C zcq0Tje#PlTj~mXLA4q(zKq|ka&Z7UFe}K$}Z*c!cz?G|@sM>?5-sp4FwNpYehmO`*rhHpIHI`x-IuVkx=cWv$`74mfBSEDF zbI9cMB3eZf@m9D7IG0Z>oVA_NUa{p9$s@q(@H^x(zs{Fr4jjI!`W|UVCaK<0pq0WH z2E0AYwk3HOrcV7tiD!4IH=8qoFwer4@vWAaSGdMkO=Qvd@UoJoja~2oPe@|e%T@CQ zIA4=*(|B!(GK|7mQWDRH=#D7{%5%C$p$$(Y*wwp+3kE<$fi5!G_5r0yy)|KLIISV? ze(tE;^rvhjYdv4X+Y`BIiy|=D+fCa$*Bpbh*nv8H8$MXbB!gzEIsV#V1&6kcNK`B0 zr$vkXd0m*CWpQ}RTqg?W7$)fLnp;kDQmT&yAg5(aVw(u%F^-TEwt^p6*kY$cCpf|+ zQ;28{?x+ZIt%cWPs#NdB^EMVtW^*k~x=Y0vTSNqz1VcsCir*UI+RXKUw4?E{Got_^ zYV5d04(c>!5nvYDqeVeNRNwOJFWW%4_V?q8pD^NFCThKp1DTdIF$9x}0$n>Pq;pq7 zsT|Oy!U8)P*4PwlgehtLRFzZ?J8pK3+4zNLj-BbAh-KWi=AiC=MtryG`6k@1VTV}4 z$)H}s3zIM(5{#TLX$Nf*5&2DcLj|xqMiGWtoc_~D{ob!XNDP`?q^x0+9qXLnJpk`3 zQY$wcK~w}`(Kp%+)Wz07!w~p^ARFUdB+5(p63mEkPqZ|&BwA{fYKeZ1O_R@54ckWU zbvhvC57B9^aOx5)SJh;iXfpRoHyI28J_PiJ;z7O7+I_jUshc2FNMuxc z2~~PX!T{W2eXQih1#8&1d2;ts$Y?6EYKhV4Q@UEqRpD33sb%O7@BmC{6$P3CLZ>ug z>CeA{o0%~O#WIJGGYQFuNhVwsglWGWMJjAkgQqMUn>i~d#b_dnOP|AHTl}(>rf%SC z2e@GN&_jCcafq6}khd4E(-%nlf{c)Tgv;v~GZM;Gmip#ff;=%6DHq;FBSboOr*3kw z!sNO%oPhMA9Usa3mITq?k0DpWA6s05dD9fPJ`+K0URjcjF)KQ>WH-91PAr85&K6_0 z=d5Gi-!aC|iXIKXrhvzh9$@fko16q7Axd2D!C3xw3i|u)eoC$Nl~mX8Hc2hH_q$4F&*44xGQ*~XqZw((eDIpX%C(P!s*58;xhS^Wc3L?AJNEbBO_Rr_W z2mbjO5@WT&$b-Ix1Gu-*C84-OB?x>BkZAbMune+X*Bo2)@Mgsc zGiei6s6dqJp!es+Ue$=vm|F^D%y)Q5;I@zn>2Y!X1?qZq>ILaF&LX%w4NH+DQuvk- zN{L890>&_UTQy#c4kVX^_#UI$S5aaJ-dEv@cR= z+lZDV24q5OMpNK)dw&?Sz-6*Q4zOo!qThWtdIatQN^@mw75COp!Y!U~S$+@tM884g z=%V(_?Hcv9fsY=-|660%7CJMxg|8`b$h|pJBroK~9g(a&LLrWe#x*Se?XaNEVj>sbeeWQeFbQw$jaJ2 zaa(GSMU!bpkew%gW$%wE|CDD|nRyk85pMZB5IQ*G94alD7CIFx@>8aKXV_fJ0-5(ME3kotRo!fI8mTBobg@zx?t?a(=JbW$1u!a*%A{EouKnQ&l?;CrvlnQ8SUT&Xy#w59VOfnS0p5p8DNHZ zDkt^=3?vzm;OG4WZL8SH&O)$^O+4K@^^BW-?GN(v)-^HLRtjBkMyE*{%_aLwyfB6V z-ek4#KQKWJ14AB*wd?5SarA*wXy!IxAU(u3n$Vt7U2bx-^+Mc}3%fS`>BB~H$lEtW zq#=ABzpLxY9=N(esS+O$;K1tJx!^nV8T3 z5_S-(sXBwVw+4;7)NDrtRdcUGEg)6U&n5y( zI#=@O3cIT}A8@cDpNM02>?JuUS@`IxVI`?mLM_47IlV=r{qb8KZ4Nh2?Tym$stug`C)>hx7GOI%1o&wy0*SO!-n^E_d=jFiyO=y(=q>4TU} zoYLij1?*Oswf0EFz?e>2WO8ued~-T?3(`nYQGO3^lNOdr@})Qdwc)tL71dOTr`n=4 zKpfnNflG9Z6qYd-kSUL*8F-{-NB)c0B!8thZX6CjFU*(pH|A)vx}*I#E_%ltUjduo zsd=bQd}He+lbu+x)i}%>y6%E1qA$h*EHm?3#o8S#mXWpt5?7mT3|LmgEpD=@HO(1bJ zr!5-sdU{<1wUBCGel8@(SD!dL5^?0H7L~<%S_wrpRRVDfUu^7Jb7lm#cL);sRy;LV80zC*yFOKWyhP$5l{kDH`xZr8O3Dw4vG z)wWY2*?ASe^?>oTUKyXiK}9NsT0)q!MPFGW$` z?nGD^LE=W}GG0sn3?AZvjAwdM88nH?kM#` za-?+>S39vzl%ZknFp~wReDHqwOmLR>&TN@GQF&Gi?tvBA#^V#_LVRNX>P1@?k}}Rr z#b$7qL|1;5?O_!VboOZo=IgJv%B!-o>IgIu^~%I2D%4{_3O3#*&mY7S+b*+Og%|Tb@WW3N6;OnLE5I4OMS*Lno+4I3v7crLsg?{~#7_xfSBInld&Imb zh(}l+i$C5Fcy!Q;pR9&$pg%Fem57l^u9b26$8GvonHJ@8GKIerR%!nfB>xRSm$SQ- z!dxvKh!-^$siq&1zdQBG`UMq1JjftAr|}bvCR#6KS>g2=7&+wnCc`wv>ZepA{`sdf z5FatgJ$LPOiJg+;^ISaOhl}t}v)ED=|vq=_=K5t!CP#T5Liu=(_R|q@Br5R_K(!`EcsdQg}FUHU_ILv zl-1Kz-^ux7>btV@7M8Ksaf&k$lub%ANhE_1=9;%Yrc{-+*(6Sr83T+f+38FmXD*5n z-e0Vzl9%S0p0^SnOudqbi`Ou9Lay{#+##h|sCUm++M*?x#$2i~MvUd#GV>J=;d(3| zS(_K^&AO1QZ7}PN1{@pkV5>=djSoLi!@4H8YGbF?!h8UMJOIT+&^MVCz66kLa;mDH8EMjuSZZO~O#6^5eoe{hYX(-7V z#WxqdBSTP(3)Z+1xq#jV@Q`V4xK1ZcJQut_7)Z2uQvnmOI^SRKx=~n5DPhBw+*SFd zknBnGR4oCfbfP7GPIf_~VQ7tk=*t%|>AF*2Q!HIPYuI;{xfliEDCwRZD-fFUa(|J-;+n0NWTL`ZLiy1rOZ8uJ`kENx*LjI#-FHOf<;_ULAeQ$@qP1F z`_^;qTf7!!S_88JpM?y`70^awH>zHRUx)Fp)6RZ)X@h%S_NtpL_`_sKm-yM2VB|B>l7{DT(bt(dKURe&@dh2a>Q z1VMsmo+(AOQ?3tgyWu|kWoXk6qAcNe6xjCw*#l*&+)LS03Ua5J#dmVO)?&lu#~q7F zGkz(tK63Gub70M)k%yhnlSFHbeq29Si!F%-#Hw1qd?!}Z%=KnAscbpDbG5(3%GJvr4ZQ>lDXav|LrX$I zA~(Kdkyn)a)2JQ8H|PP%2;_*W%zooNmvq-$S?>0?mA%OL$LO-K2!NyvM#tmI?~Dq| z#!rw@Kv0O$od3FVMvH_~^Xf#+0Oy#5-Ujl@K9#&WIw$g;w4Y_GH;ivDsREsyaQV{J z2(aATd)|3QjopgZl@h=9G96Kkm|WVOJbwr#on`HfjZk%QVTHRaV(3f?v0fF$b2-CD zZjX86A*_IC+yxX)hu9M1H?uZBt&SxIf8JZd+4#)@IqmXX8AZPlow-80OnQAxL=q_1 z9=09QyKGt6iAo}-xT$^%?KS}{lfW(v>@da!!r85p@JAqdKbAYRYUvgqJDTIM8SteQ z_LQ)<#+?w$^K)$EV}49&D4S~lnJZ3v!p6=U2RNt_^TF^L#M2ICmXNafBVUiigT$Mz zQ((M2ywhRxrL&|dzQh29(b^3a1~0#I;=^rxA+M(ekOy>b|PyYMx^x)>$w%_rc63(YHzq zB?;}!QV|fTz9jvWk}FmpP{F+(u3KR}egwpvoC&Vupu$kK9_`{efrW8G>w4a^BEUqo z`(;PgK@o1CLuJ*C3wX@+rgKcnTBe|o0_I(8v@uSZ-ZcLz2`nD{K%|-2iFFG0Nl8sa@Y~Xx+Sb0AZ~ZMqv!8a$ z-VVaC8L>DaQ1XHOv3FG#$_v-G!TkoheZXrXF%vVDQgmS%F5Kn99GYNV<3g zt8}72U2jGk24-{iN8QfMgHuz3IKJVFpzD2Gti2#z`B;REltJHZ1Xmja7p&ICGIBvHokc3$!3MhN8%y|5bM*y?wE)E5&Y=pCl1jd%6g0(ho z6NQb#3!T6^z^>Y#9rSU;*{@4l+OhoiMyW^}=RBE?T!8t)y7$P4$hE{^J%ZcWcouxD z5sNaHjiYha0Dcv48 zMpsuM*trW5;WMC={I<7y{8l^PKFdZ2s-tuiz_C{%b=J6)cVe(|_LVa-oF<=P4wekx zz)_Lf^4Dx)3=X04qprOHDL2)%s#sMX%*?pTFt_>qRD52@Ks^ofQGc$Ca3~kr&xdag zXJ?=^75f$7`~-tMRFO4(nl1q^yqkDML1`6ek{iW@RWYYyiP9`??~OJmHPz?Zyf`9R zBI_SixAW^!c^WA?IM!{M>T*~D6SsKu^ez2LgngyuAq1agdc^cf_A|8&yUtlYsxFvI z83ASU3DPV;KZvAc4`Pj>04X`?JiROTTxjCR;BDDx{*0Cv2dBT;E*?M4RON6D9M6pAaGL#TZZ1Xlvfr^5} zt)mJW;N__(=Ok}X7E!Ay1zaUwuvh$VA}2`(YCDvoV42Xjw&v8?yk^(j!5;`vq;fZJ z=&DLiWAu(PvLd6eV++E|%FVKbaeMNW8KGBHI`gK)f;!5c1p?U@E;Vp&566Ys$;cS! z%E#d4^Bc@suMRPnT4W~MzQFpJi^u3JD^3@|4lS>hO_rq4OSjOiSDz{fSk;lH-<63t zPOY4vuS^GDoXy+%w#3~)GQGvc5}kRm%g8Sk7rwRjM_!sx;a6$ld*$~Dqqkw2xp_j9=M-B? zMNSiXl4HK*YfX6~v)Zzsu%ZI5E4CI*pAW6P_*|E@+1d)d#zGIGXekMW@wWofyq72~ z9eNdU$Y?EB0($W(y$cw6rAG0C3fbY0?Nj7gWhLZ*R0&lcc<=eb7~atr-gGCuHL?w zS~kL!)Helq%1e%9-ibV(l#*EE%@|&R(W7G@im%wU5l6E}9(I+f;+0k(V}Vw5t_F7W z9{J5S@v!iTrO(|X{zH)6<~YVZlx_wA#?EHlYj^AOc56Ag)dq0CcnYuen$;q|c!8iy z;WmeCQ;-A)&vnN2+6sZl0)ScBUFzLh)=riy@$oB*{>EC{{xmv_C}R4F za!b5Rip}gIF*sG;yeio`-p61gX=A*Cu{g4hOuBnCOBzvWXqacahoclaT-aw;&{O(8 z9-}e;;L$^VzGX~>rWeO9P{$a^G+r|jxzF!}o5KCf%I#QGk=uUdD20KGS(njzBR*ar zJ{@IB6O;pgA$0k&mZ55}qqN5cb;7=%rjD4=sM|8(-L3aol~2(64!0p`NvzDdr}H-o zA4x!pR;8WrY^`oEPb>_&U4P%Slx(A~U|oa*bG`$^l&Eg$llke@E-@0O$68(0td09| zPk(K{p??oSb(DE%#Z{(%05<;m{BJT2!uGzV5GsUp3y1SDK345V`4Y#B`T?eVjI8$o zxSnweU}#K zbnf5amys1KTPS03^xQZ4eC1K~lGz#YrdOIA!5(7KL+-x$9wPB{azXQ32~YU+F&ByJ zw47bw`L@j>yl(cp&+QA;ideo2)lv8p000$cB_^gUBPRBbV!PK8yBxnn0qH?ul3~L+ zSqXY%cTA@-<>7(gipXO121I;W-9in7WVyZq8L_18ZMt@Rk|*tI-gfSj<4th?>LXbd4n+~dXB`py|Ckeyzh0|qCsQb&@W45z6>gXIoc=mAR-V2aIlE$+<% zGkxKPL2mf7i2uvuT7I$CcsA;J)R2oj7sEE%cBX>dLAMf#IkgOhAT1f!VenAAUb?>j zj-IRbW~MP^auzK*PRuZR8ec{#YN}@zcTok=9*Ryn-jr_6f^2Nd*|;I$XPb9cwR0qr zBy!R~BrH~Ix?*S)mG>N~@+Fo+`&;DBPcqKqyYwN6rcfFc2_!;y5M?=J4-F* zOeLgHs0>)2KFoIR?`Qnlw12a>GI|7)P*|Jh5Evq6)GWPxLiY3Q?8oT_Tg|gSz?j6j zAWp$-=d~)5(CW4NQCmTt*VMs|$=J-n1j6KL=lEJ32>|d5c{&=K+CW@^CJ+lNdjZhT zu09aZ%1i*H#i0OJa1?`BT1k65L)5$#)lI!^OnJ;eLW0Qrp1iLBb`V!%pr@U!y$i3W z0O&7V-q-U#&CDR+Um~tH0w8S#WuTaYGX%)a#Lfg}l<>52X9Wo&1NoiJ%z0JCCI1fb zdL;m|bai#)WoGv9@L=*_V{&k|U}oXr;b8`|GPANWzDh8Uc{tEJUgZ@_y7xmX7Qf5_%i-Vi9DMZ2@V(&`%uMlRY|I~MMbGH4<9WzsAh%LnK zRn+BmRF;1mQc6Za`JWnpD6p`ybNox|mF$0$bhR@7AF}?^5f=dc8K2k8!PLr(_pehP2pA0EF=1geHs|DKWak0%FmiJl zn=*n~xOmLDOu4za%((vrO2*#B)!5z?@(1b_oXP4H$DEssliP%cozc{s!;F!g8_dnf zV{T%?Xu=8R;WRTbhj4+p{sltG+3Gbbjcxzcsy|R>uTT(HZWay}6E;R;Gh-G;c4Hnc zMiXPOF(U_$DJK`inA@0xgY7RUGgDqk2WLCu*Kk_d8CyV@9qldt>i9!AuZXgY0Em?d z{68(qw#KgJuL`eoz{=jt!NcW$y40=gAZo70fB0nK+lfc&MuPz|)uf*jwHvQWmF2?QK z1>|*x|2?Jt(Qfs>gp0)-Y;I=GV#a9B!ou|$afk^c54#EYHE^cJEM}|_9!?&}zoWZ2 zn7euyJ3~Y)UOj#F<~4=>@&-uvcQW7pyS#@bFWD@-U=Cgu9uV{2 zon`(rr~lzCKlA^^2mfCJ|FQ_Y>iw8#-+Wi>;V-PP=(>HKVEs+uc1 ztLSB`#Ai5z6jn7_K!_i|OUfXvBqS+(Q`n$pCC-(@Wt!(U=dx#G;}Ka<6y=4xdw720aogP&2^ehdXfQR!SRZ!USnnzf zgIl22Uh+|%kJfqFxyjdag6M<`OxE$RQ{`}}Wx4H*^Ilii2Ay2+>9fn@t%b=(r)QU{ z>`QyLmE|%~Pg%#~%-Iw%+E9i~eNWH#HlN$G5l?;t9K?r7BPHdS3Pi8WQB{2GC|9b^ z8cK$sdbm&6MuvP|LHYcaGH8q+y-JvhH||Cqu73Q!UcXX+*}i?$eSSKKgSp-4)32+p zHanQg<$qjjqAR7DbkYWQL%5ng{zpsxFu^MV50_JyZwpeMf~5HrK6 zx6BIKasNFnCL&l+@N9aokyrTWX?9HkPE}X83aVtzio{~SNwL19b~JMOV2-24=&B?o zGaFf4RtNd(>S|2ww6)i;JV!iS? z#Rx1dBO@~eRsif>dhIE|fkMyCo0c&q8nWO*lT@cZQkGe<^70ZfU3jtw?(gptBbz0W z>pU>a$tA!4MLx23M<0JSbJebHr*FrxE4-*fBJk46^a9kVXQ%UJA{X&Uc*W<<&BHTG z6ajpt+;T($YSujup}{#T)Dye2r{pD-D<1QxV4eNi6tw_&k>G z?i=+`2Jw8EmOJSbny^10K|Bn~Q2&)g@d4-F*WcpCu<76hG$TvW>+Exv(pKMYU*zht zpP?EkitrtF5BP(hF3KJLrl&QX+}00MjLV!I-ewEA#4`IVc)srHzu$O&e9 z!Bd2?$_huuS6j+*i6DmN?qm}9%ZS;*JY&B!dleti-}DLuhwRpdG%;|tlEJ6rZ^Oo; zQR5d>FtcPCqXWZhg)-i$AVIwLr{O`^LDK;StlV^#HrZi}lYs9OF6JNNa7b;RvSa54 zN%t}{_(Ghi1d&FwfaPMBNP2lfTcp2=FbGsbFR*s178Vw2hhqp{rimT8ovb7whN@k= zDw%2VN~CL@3&z99%rg~0e6>(f=+Ph)f?wU|!3rL?sQs5#6|;Boq|@8Cisq1)*D}Mt z0`ldzR=RT!Tm2n&=lL!5r36dcT1Xy5gtW2CPg(4!riNBlM`EM#w4TXdwispTWoOi9a4^u0Vhj7iL9f`O(xM0{E9@9)N7R@ zxgtc0TKxt&786i7k@KPcH(k#Hk9R++LhLLqBG9q#YcNi?b9gIx;+lAK6$7ZTqn?~> zZEZ1y=NA_I-lfX^uJqi$?Jd{tm>u1p6iC*rXCQnNq=z0nfN5t}`r})ov8AP~Z<@mP zJY6-fUs59qh2{I%(C^gurlz_g_A@aVf_bI3FMlJ;eO9u?Yjelh(1%mXi8fKy_Kopi>I zDhi~?h>tW)_zy4-d zn>l0dje3Rd$+rBaU;9&=;{*z^32a@C7;2Qv2xO_&DU@(~-6z@iag_(1M7q)U9vp!l ztD>U9K)o3L@bI8S+-j$V@1U*$2LqFIx{7k^(5u6JwYdo_R7RvLY-_{q6O!@i8usXg ziG#`FL_+#pg={;q-!uJP^-g~_M>voPC ze!V8?QHLaxAKVe3teFr`F`8n7?!D;8)o{Lot0aF&x6_rLSOtUtn z{X23zf~*{hyzM$_xssR^f?hiyo$2jjU0ckXD58F!evXem&t4(S-X?}2o4(iv6h=^dGOwvP(5T(fcvd1YOnur6H zAEYz32SrHaoG7c)eVsPsgpBIh11F{T{&@RhbWpF8D*9cK5GH_;kuj*ZxA&H0G)nP% zcO!PIeT#PU*g#`J@!)1@`jrkyd1vF{@iD+tAf5yf);~*{%3nLjH8nk5O)sir4}Z8! zL1*oZ-M?@6Qy6^fsp+jfhJZj3w=o|p7<_J}qOM{qO@$rcOhWt1$=O_g34@D^%fb6% znBb*|RY^u>+(LeCjYm*$T^)SXizLLMR>1vzNC`H9@^#&?)6!b%kfABAt+m(S&GpxL z+j2!2{EZwHzAazSkM~i$Y0I&lb~@XEUWFU8GbZ8()Nlj2>E@cM*01n$pL_t(&-tC%skQ`Ti z$3O4r?wQ%y)vmPC?&?_GMzSnn%L0Kp%uz;w2!>GM3Wp)F1E~Zk41^R3aWI6G4JN6O zGA3Y(ayT7gbC@7(Kwx2lgk@vNI@YUmwOVPf+1WX}`yKhCXIEBar|iT^;e^-qrh0mM z`n~V_eShEI@BL=rx9$H)Yx+~{KDPZaKRZ=9@|2G!o^k+gnw;#IeLpbr5Yx>G>Pdy= z^VZSRv6wK7xcR=1FmGWeuV41T-%KC?-g`#NLwx4mKV~8xnv3v%o+S3g-b4@d7uW4v zTwJs5T~~bM_+x$d)?Z%7J2zkVzYk<&`Y?SRE6%!h_x`UiQaN1w@v+<9H{KZffOV$B zSt%L~%P1-~FO$sdR+Spl|m5WObC0%3*5FG7k^` z60Z$H5uU0ZzN!{ae{`&Ie9`Ip5g+NCP*Nd;1TRPvhmsPl0ObLJ^NvQ`q*hPp3)c)j zqkGfuzisn}b{3;9I*M};;>;BHkN<+T-Oqh;K)m;7J;Zy@bfd%#_r9IJ_T_ZtdUDmq z^t!Ryi4BjGezpEs<=`6%QLr#jA)(3<%7_evLJEmM;tVJykxJmb$9sqK4r48Gk}_GI z^cOF>Tx?#t=d}k%cb#n4^VqufYWn6a1>igTZsye&zWa#*d3gL@)^)#N762BG zPVJ-I91Fg6;HLLHbn2&nP-~V~*_1#>5Cu6xl|xC5mKr5AS}J7gTndF00)Ye}T7!CA z3y8yEy~TS=)6{9CHBy__I`zU&ZR*={<3&Bss~O|?+4fz0@=rg@p0S^?e*O!em__bC zxP$h2IT}d~5Db?GUbt=Wi=Ul{ht}7db&@#6>lCRZN(KZnKue950ZM9=4A4TMWd=kD ziA0_m(SyU|yv@3^7;msH#kdsXEUAmB#--uTpzmW_mS6qF1;wRy>-u*-Icgm^y^D$3 z2)8|SUExG!|1J5j@Rpp;qkWEQvqB}FLI)D9T9Z}*p$u9;0<_40DXCCWBZWo?F-zB3 zYB`Jb7V8Ygn-&OzbqQ$;RBW0gX}ss{8$R*Di{@XxZ9{+NCkIA$v!-t&0Q&KOe0s-K zSZ6xRX5y}V*mhYVXd_ZNl7_`vi;!g87YZd5S|~(o(z*pisn&T5kQ54m#Nz>nbq*&j z!kG-9%S`3*c&|~y|CmrRRXjM31mblBSIAssT_gK5vqtlg#@ZaN73>x zp^-8Z35m#jOe%)z`{|#z`tOd99pYr^=&Us!6UbOS3%Hd@$6Quj?wTRqcml0aQX{;= zB$6ZsXTf`cB%_QJvenhB!_WAQRw04PL?Hu^^;w@1GggzCKef6LGNWW`s^;8o!sDfZh2f$Er30+9c_<_RYw;;JJIJz6>f>CqB`*0Kn3Mn+~P zg%C)Q(FDK?`zYrZXB{BUlA)RV0u^$sw4bygFTZc_`>dY7k@<6a&j1l33s7Uz!+dl5 zE&Oojom(F`vghXBrO?+qhtMmGOG#}?mCy>l5F9?KR_W-8=;)*TM#Gg+11U|XU99)|_M zl1Z*}2Inl!Wx>%}i!lb{9mYCR<4BDqH5QwKYe-uMK z#&t)dYEWT<55ap!YEq&gq}ZwGY=q=GAXiWXN+KnAF%#q@)*GaoiQ^vSRSOU;OQcw5 zX1ntiV-3wDB~BBJHKf*(rVe90IUNxwM_#r~tnJ&#qOKL^0vR41VzNAjN$s#`ExvP} z=~F4*d0dwzmIl*o5-5!hK({A|K;gW~RuqF365$2HwfOE^llB%T)ENhw$+Min`c}6F zp*_+-qm+<3Ly{V-u|z>c$J}<>x-?x;vDDKup9LK~=K@*Kxd@!Z8+Fp85c=$TQg=*^ zq*SLYK|Uo-K_JN&B<=ISBe2fS>J`Fd&MQP_2cP9s*0tmmffub@t3@a0%xrYG7#s#K z9QCT9GTuZON%zWjv{V@3sil*ppC7rCIl1}g0@)6Z+D35aiPP8Z`WJ`@i%b91yAQJ)W4aQr%Pq8+| zriQ7b4N4~xf%n?#?5UM3X>4)MV5}iADa|AyNn?ynNNr5wVqzB)+a~q6L7X;Q3YcWqU3O1u z6ReFfJ|!`RW-Y}u9cdlXrbp&1P1C4M*UGmDr@y6K?&9Nw#J!c{Bc+Pvjb-X-KsWob>=(?C^ zF3z^wkBt9{)!m!U&VE-dT1T3uJT$oTbgj-yl;leqzp5o-2nWuC$P2XAL_tVfSRk*9 zFKPO|k);k%&;CWk94O@l5fU^8wqFtlfKeCpI$iQ<;EZ#`GF?mMuJi&tI-z>)F& zT)6yFw(b0v>0+VyM-LAE;@iI--1E6yjwRkgfJf*oZSd|<359p)K;aWjby#3ZDS0U& z62t`$LK23WVp~A_+yE6gganJE-ZU5!(~KKb#$(ck$60U=4>ZFd*9^nl;}%F}fn2s` z3jn*1Z)bV;87De9b&Rjw^N-)J)hicGRVQySsk^37up-yt5!zvWN@`8)S>v!5gYKic~(UV72%o_t+v_mS;vTz+;zZvW|Da%6H3ckKWBb@jA-rL*o$ z&T)}e0b!I$YrPzE;{GYxcUcl)7``w82gR~R2ZFfY5#=Rm-4RzU-h%MpjK(GUVPWOp z&g<;{`rEetiFw_Nu0n;1IpMtjeu3_>fB;N1PhwKbp^<%jZ}(T_U38%oq2(^4V|x zt1CAB-na9*%{Ag0&);wb<;El`kQ8<2Q&%#5VDyJvvfyQBYF@zSe)w@F8YkIT-X4{! zL$ADS<<`dQo_Xzv8?(3E`qB4qjyl`9>Jv9zarZaBbWd;Ja(b67XQ+IbyLNwb)xhxH zzcAK3dui|L>)-i`YrnCgZ;dOLVixxFuw=oCvx>yv?@i|f<-uH_gwPXJ1AKW{@Z=@uUgmecx38vW3^!P*9Ta&@IqEE-9UV#$*&IH zJNOUpz4NMESm37HKTPl3e%37Bh*)xF@`q0EV`a~USz`M*AfA$H{O7k{&owXl%QL0b zhG)mN+c|M$KLdMq{p67ccU|tiW5v3QU(>gA)pwSy*}yB_@~*S$TQj@V*$PhSAWOQQ z@ucP<|EEA^KzLtg{KNnvFPPighjW(0dmoJBMorWzWpQx#zpFxfJAKPnB7|V{#9^kY zqqF;Q?>&{c1n{ImoR@ab*FF!xCg7uQd-H0qI)MOH`|&g8&r-^e$N* z<7X=G&IR7N^9JO+S)^Vm(`eN3&XF{mj1CvWy)=jQm zh`~Mg^M#LHd-e3>1#EfK)lUys R3mE_a002ovPDHLkV1l=BoWuYC literal 2079 zcmV+)2;ldLP)da}F{yyoEBSkwZ*74sIQ)9a%Vg**P6c-(22s zbzt3=YkO-uLXfNq*DSpG)~miFz=#R~PnnL>t>@RbeC+w5%?cG0=9yH-;_|NZ`m@~z z3zv3%;)V!J(0*Btj(uZFSkhHamY;1Zn{O*wi7B?^^7ZBVNT zo;5nLI!#SlFvV0CQ&UJx!J5=)Ym_z0C^QC*Lah|s^X%;`JT))#)uYvZWTP=jbs+|c zUWAoGrIprbG&Uw`txl{eB)X8AVxo(QPOVOivRWB~Mk%dODO9M`5w~ks|MsbQ<+OPY zF7tJ<+Gu4^jLU!`fFJ@kEEH<A11LEJ0y)XrD z>(1YQblnBp_HGtn;z%4@Tg#H`yv9D`7=%S8LZxvL01=pYD#wlBwT<`COFwyL|D%(5 zWA&jg-u=nk*8wE35A5@pd&;`z&B-d9*D1IV1FB} zPvoPIgD=;H_k_x57RW~md8|$1Eu7nPWz*PqA|MPBMWWP3h=?LZ7kuViB^Sqx~6;k{FG|1l~*iSZtYTlaeAP5~fHT z8vQ3B&%biz#>I12l#-??`u(!=K4euw5r9!5NC5G`K^c{#rZA(>JhR;1J$s4IV`Jqq z=dvuX)qG_Di`=F|(S}mlHroO!10Xu}+yRbIsUCrlpSFeX+YUVGTRW7G(EiJ~HATG;tUlU;ffsyfJFj@bu zCnB!yxq5Za)z9sH;-+t3Vu%YBhuPIcvVq^Jek^9Ak_zUh?nE^oSu+0~7p{!~{k(>a7uWRwxv)~=y{oK#zcPx6nyyF_n zhn{-nk*{vLvE%HtG(&e57A(y!{nPp%jIL=P860Y_&Zuufo* zd+y>=+Vr1pdfmEpC+8JRsk>t-5e?K2B$>YTy+7?T-H&g2;NJUQDE0Z9Zd$)`;kyqU z+be?SoU!E2o9|z_=sg{6bFE3Hw&T~W@oe!!}m$p6f&~4Ygt9SQK zX3l(laP)BQvs0Q(gV)gSezxIL7o53vap}6ZxBT))-<)pxw7(xHhR>{7ezdQ*sip1i zM_)-xQ-@5JHg@?XR{+4WORktM>~welFz4)Z0AT)-b5A4pba+Y|05J9hJMazX zWwmht7(CSb7V(A$4g col: # Away from the Left Border of the Screen if grid > (col*row)-col: # You are on the Right Border of the screen - You can't go East miniG[grid] = [gN, gS, gW] - else: # Away from the Right Border of the Screen - You can go East + else: # Away from the Right Border of the Screen - You can go East miniG[grid] = [gN, gS, gE, gW] - else: # You are on the Left Edge of the screen - You can't go West + else: # You are on the Left Edge of the screen - You can't go West miniG[grid] = [gN, gS, gE] # FILTER OUT OBSTACLES FROM THE GRAPH @@ -199,7 +197,7 @@ def generateGraph(row,col): if grid not in gridObstacle: # gridObjects.remove(grid) # Dict object has no attribute : 'remove' # HACK - miniG2[grid] = miniG[grid] # Created a new dictionary that stored the values required + miniG2[grid] = miniG[grid] # Created a new dictionary that stored the values required # IN-DEPTH FILTER - Filter out obstacles from the neighbors-list for neigbor in miniG2[grid]: if neigbor in gridObstacle: @@ -214,12 +212,13 @@ def generateGraph(row,col): return miniG2 -def drawGraph(pathF): - #Draws the path given the path-list - global Ucelu - #print(pathF) - if (Ucelu == False): +def drawGraph(pathF): + # Draws the path given the path-list + global Ucelu + # print(pathF) + + if not Ucelu: for grid in pathF: # g = gridObjects[grid] # Get the grid-box object mentioned in the path # x = g.x @@ -232,9 +231,9 @@ def drawGraph(pathF): if grid == 'rotate_right': player.rotation = (player.rotation - 90) % 360 if grid == 'rotate_left': - player.rotation = (player.rotation + 90) %360 + player.rotation = (player.rotation + 90) % 360 - #( player.rotation) + # (player.rotation) if grid == 'move': if player.rotation == 0: @@ -250,49 +249,11 @@ def drawGraph(pathF): if player.y > 0: player.y = player.y - 1 - - # if player.x < (x/50 - 1): - # a = 1 - # if player.x > (x/50 - 1): - # a =2 - # if player.y < (y/50 - 1): - # a =3 - # if player.y > (y/50 - 1): - # a =4 - # - # if a==1: - # # player.x = x/50 - 1 - # player.rotation = 0 - # if a==2: - # # player.x = x/50 - 1 - # player.rotation = 180 - # if a==3: - # # player.y = y/50 - 1 - # player.rotation = 270 - # if a==4: - # # player.y = y/50 - 1 - # player.rotation = 90 - - - # tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) - # if player.rotation == 180: - # tmpImg = pygame.transform.flip(tmpImg, True, True) - # tmpImg = pygame.transform.flip(tmpImg, True, False) - # - # #player is seen on the way - # SCREEN.blit(tmpImg, (55 + 50 * player.x, 55 + 50 * player.y)) - # pygame.display.update() - # # pygame.time.wait(300) - - # player.y = y/50 - 1 - # player.x = x/50 - 1 - - # ----------------------------- i = 0 while i < len(T): j = 0 while j < len(T[i]): - #color = (255, 255, 255, 0) + # color = (255, 255, 255, 0) if T[i][j].isWet == 0: # a = 1 color = (160, 80, 40, 0) @@ -300,7 +261,7 @@ def drawGraph(pathF): # a = 1 color = (50, 25, 0, 0) - #Covers 'player' on the way + # Covers 'player' on the way pygame.draw.rect(SCREEN, color, pygame.Rect(50 + 50 * i, 50 + 50 * j, 50, 50)) if T[i][j].plantType == 1: SCREEN.blit(imgWheat, (50 + 50 * i, 50 + 50 * j)) @@ -318,7 +279,6 @@ def drawGraph(pathF): for obs in obstacleObjects: obstacleObjects[obs].draw() - for bx in boxObjects: boxObjects[bx].draw() @@ -333,30 +293,21 @@ def drawGraph(pathF): tmpImg = pygame.transform.flip(tmpImg, True, True) tmpImg = pygame.transform.flip(tmpImg, True, False) - #player is seen on the way + # player is seen on the way SCREEN.blit(tmpImg, (55 + 50 * player.x, 55 + 50 * player.y)) - # -------------------------------------- - - # tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) - # # if flip: - # # if flip == True: - # if player.rotation == 180: - # tmpImg = pygame.transform.flip(tmpImg, True, True) - # tmpImg = pygame.transform.flip(tmpImg, True, False) - # - # SCREEN.blit(tmpImg, (55 + 50 * player.x, 55 + 50 * player.y)) - pygame.display.update() pygame.time.wait(300) - SCREEN.fill((WHITE)) + SCREEN.fill(WHITE) # pygame.time.wait(50) # pygame.draw.rect(SCREEN, WHITE, pygame.Rect(x, y, sx, sy)) Ucelu = True -def UIHandler(mouseObj): + + +def UIHandler(): # drawGrid(GRIDX, GRIDY) global Ucelu - drawGrid(10,10) + drawGrid(10, 10) for grid in gridObjects: gridObjects[grid].draw() @@ -368,10 +319,10 @@ def UIHandler(mouseObj): obstacleObjects[obs].draw() if pathFound: - drawGraph(pathFound) - # Ucelu = False + drawGraph(pathFound) -def eventHandler(kbdObj,mouseObj): + +def eventHandler(kbdObj, mouseObj): global boxes global obstacles global startNode @@ -380,7 +331,7 @@ def eventHandler(kbdObj,mouseObj): global Ucelu if event.type == pygame.QUIT: - running = False + pygame.quit() if event.type == pygame.KEYDOWN: pygame.time.wait(DELAY) @@ -426,15 +377,10 @@ def eventHandler(kbdObj,mouseObj): # If Key_f is pressed, set goal node if kbdObj[pygame.K_f]: gBox = getGridBoxes(int(len(gridObjects))) - # gBox = getGridBoxes() - #x = mouseObj[0] - #y = mouseObj[1] - # x = gBox.x - # y = gBox.y sx = gBox.sx sy = gBox.sy - # ---------------------------------------- + mseX = mouseObj[0] mseY = mouseObj[1] @@ -444,15 +390,11 @@ def eventHandler(kbdObj,mouseObj): y = g.y sx = g.sx sy = g.sy - if mseX > x and mseX < x + sx: - if mseY > y and mseY < y + sy: + if x < mseX < x + sx: + if y < mseY < y + sy: posX = x posY = y - gridBox = grid - # SCREEN.blit(imgTree, (posX, posY)) - - # --------------------------------------- bo = Box(posX, posY, sx, sy, BLUE) boxObjects[boxes] = bo # boxes += 1 @@ -470,9 +412,6 @@ def eventHandler(kbdObj,mouseObj): print(' goalNode x=', goalNode[0], 'goalNode y=', goalNode[1]) - - - # pygame.display.update() # goalNode = (x/sx) * (y/sy) @@ -482,10 +421,10 @@ def eventHandler(kbdObj,mouseObj): # If Key_x is pressed, spawn tree if kbdObj[pygame.K_t]: w = random.randint(0, 1) - f=random.randint(0, 1) + f = random.randint(0, 1) print(w) print(f) - img = generate(w,f,random.randint(0,2)) + img = generate(w, f, random.randint(0, 2)) img.save('./test/00/test.png') data_transform = transforms.Compose([ @@ -500,15 +439,15 @@ def eventHandler(kbdObj,mouseObj): target_transform=None) model1.eval() res = model1(train_data[0][0]) - if res[0] ==res.max(): + if res[0] == res.max(): print("0 0") - if res[1] ==res.max(): + if res[1] == res.max(): print("0 1") - if res[2] ==res.max(): + if res[2] == res.max(): print("1 0") - if res[3] ==res.max(): + if res[3] == res.max(): print("1 1") - #img.show() + # img.show() if kbdObj[pygame.K_x]: obs = Obstacle(mouseObj) obstacleObjects[obstacles] = obs @@ -527,44 +466,22 @@ def eventHandler(kbdObj,mouseObj): y = g.y sx = g.sx sy = g.sy - if mseX > x and mseX < x + sx: - if mseY > y and mseY < y + sy: + if x < mseX < x + sx: + if y < mseY < y + sy: posX = x posY = y - T[int((posX/50)-1)][int((posY/50)-1)].plantType=4 - + T[int((posX/50)-1)][int((posY/50)-1)].plantType = 4 pygame.display.update() pygame.time.wait(DELAY) - # if Key_SPACE is pressed, start the magic if kbdObj[pygame.K_SPACE]: Ucelu = False - gBox = getGridBoxes(1) - x = gBox.x - y = gBox.y - sx = gBox.sx - sy = gBox.sy - - x = (player.x +1) * 50 - y = (player.y +1) * 50 - - # tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) - # SCREEN.blit(tmpImg, (50 + 50 * player.x, 50 + 50 * player.y)) - # pygame.display.update() - - #when on it keeps flashing - among others - #bo = Box(x, y, sx, sy, RED) - #boxObjects[boxes] = bo - - # boxes += 1 boxes = 1 - # startNode.state = (10 * (player.x + 1) + (player.y + 1) - 10) - startNode.x = player.x + 1 startNode.y = player.y + 1 @@ -579,15 +496,12 @@ def eventHandler(kbdObj,mouseObj): print(' startNode x=', startNode.x, 'startNode y= ', startNode.y, 'startNode direction =', startNode.direction) - graph = generateGraph(GRIDY,GRIDX) + graph = generateGraph(GRIDY, GRIDX) print(graph) - # if startNode != goalNode: if startNode.x != goalNode[0] or startNode.y != goalNode[1]: - elem = [] - - move_list = (graphsearch([], [], goalNode, startNode)) # przeszukiwanie grafu wszerz + move_list = (graphsearch(goalNode, startNode)) # przeszukiwanie grafu wszerz pathFound = move_list @@ -599,32 +513,11 @@ def eventHandler(kbdObj,mouseObj): pygame.time.wait(DELAY) # startNode = goalNode - if kbdObj[pygame.K_b]: Ucelu = False - gBox = getGridBoxes(1) - x = gBox.x - y = gBox.y - sx = gBox.sx - sy = gBox.sy - - x = (player.x +1) * 50 - y = (player.y +1) * 50 - - # tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) - # SCREEN.blit(tmpImg, (50 + 50 * player.x, 50 + 50 * player.y)) - # pygame.display.update() - - #when on it keeps flashing - among others - #bo = Box(x, y, sx, sy, RED) - #boxObjects[boxes] = bo - - # boxes += 1 boxes = 1 - # startNode.state = (10 * (player.x + 1) + (player.y + 1) - 10) - startNode.x = player.x + 1 startNode.y = player.y + 1 @@ -639,22 +532,11 @@ def eventHandler(kbdObj,mouseObj): print(' startNode x=', startNode.x, 'startNode y= ', startNode.y, 'startNode direction =', startNode.direction) - # startNode = (((player.x + 1)*10 - 9) * (player.y + 1) ) - # startNode = 2 - - # tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) - # SCREEN.blit(tmpImg, (55 + 50 * player.x, 55 + 50 * player.y)) - # pygame.display.update() - - # Delay to avoid multiple spawning of objects - #pygame.time.wait(DELAY) - - graph = generateGraph(GRIDY,GRIDX) + graph = generateGraph(GRIDY, GRIDX) print(graph) # if startNode != goalNode: if startNode.x != goalNode[0] or startNode.y != goalNode[1]: - elem = [] move_list = (astar.graphsearch([], astar.f, [], goalNode, startNode, T, succ)) # przeszukiwanie grafu wszerz @@ -665,17 +547,11 @@ def eventHandler(kbdObj,mouseObj): print(move_list) print('\n') - - # else: - # startNode = (10 * (player.x + 1) + (player.y + 1) - 10) - # Ucelu = True - # Delay to avoid multiple spawning of objects pygame.time.wait(DELAY) - #With it it keeps going, if without it turns off + # With it it keeps going, if without it turns off - # Ucelu = False T = [[Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,2,1,0,0,0),Field(1,3,0,0,0,0),Field(0,3,0,0,0,0),Field(0,0,1,0,0,0),Field(0,0,0,0,0,0),Field(1,3,1,0,0,0),Field(1,0,0,0,0,0),Field(1,0,1,0,0,0)], [Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,0,1,0,0,0),Field(1,3,1,0,0,0),Field(0,0,0,0,0,0),Field(0,0,0,0,0,0),Field(0,0,0,0,0,0),Field(1,3,1,0,0,0),Field(1,0,0,0,0,0),Field(1,0,1,0,0,0)], @@ -688,20 +564,6 @@ T = [[Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,2,1,0,0,0),Field(1,3,0,0,0,0 [Field(1,0,0,0,0,0),Field(0,2,0,0,0,0),Field(1,1,0,0,0,0),Field(1,0,1,0,0,0),Field(0,2,1,0,0,0),Field(0,3,0,0,0,0),Field(0,0,0,0,0,0),Field(1,0,1,0,0,0),Field(1,0,0,0,0,0),Field(1,0,1,0,0,0)], [Field(1,0,1,0,0,0),Field(0,0,0,0,0,0),Field(1,1,1,0,0,0),Field(1,0,0,0,0,0),Field(0,1,1,0,0,0),Field(0,0,1,0,0,0),Field(0,0,0,0,0,0),Field(1,0,1,0,0,0),Field(1,0,0,0,0,0),Field(1,0,1,0,0,0)]] - -#T = [[Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,2,1,0,0,0),Field(1,3,0,0,0,0),Field(0,3,0,0,0,0),Field(0,0,1,0,0,0),Field(0,3,0,0,0,0),Field(1,0,1,0,0,0),Field(1,3,0,0,0,0),Field(1,2,1,0,0,0)], -# [Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,0,1,0,0,0),Field(1,3,1,0,0,0),Field(0,0,0,0,0,0),Field(0,0,0,0,0,0),Field(0,2,0,0,0,0),Field(1,1,0,0,0,0),Field(1,0,1,0,0,0),Field(1,1,0,0,0,0)], -# [Field(0,2,1,0,0,0),Field(0,0,1,0,0,0),Field(1,0,0,0,0,0),Field(1,0,0,0,0,0),Field(0,2,1,0,0,0),Field(0,1,1,0,0,0),Field(0,2,0,0,0,0),Field(1,0,0,0,0,0),Field(1,0,0,0,0,0),Field(1,1,0,0,0,0)], -# [Field(1,0,1,0,0,0),Field(0,0,1,0,0,0),Field(1,1,1,0,0,0),Field(1,2,0,0,0,0),Field(0,3,1,0,0,0),Field(0,1,0,0,0,0),Field(0,0,0,0,0,0),Field(1,2,0,0,0,0),Field(1,0,0,0,0,0),Field(1,0,0,0,0,0)], -# [Field(1,3,0,0,0,0),Field(0,3,1,0,0,0),Field(1,2,1,0,0,0),Field(1,1,1,0,0,0),Field(0,1,1,0,0,0),Field(0,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,0,1,0,0,0),Field(1,3,0,0,0,0),Field(1,0,1,0,0,0)], -# [Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,1,1,0,0,0),Field(1,2,0,0,0,0),Field(0,1,0,0,0,0),Field(0,2,0,0,0,0),Field(0,1,0,0,0,0),Field(1,0,1,0,0,0),Field(1,0,0,0,0,0),Field(1,1,1,0,0,0)], -# [Field(1,0,0,0,0,0),Field(0,0,0,0,0,0),Field(1,1,1,0,0,0),Field(1,2,0,0,0,0),Field(0,0,1,0,0,0),Field(0,0,1,0,0,0),Field(0,1,0,0,0,0),Field(1,2,1,0,0,0),Field(1,2,1,0,0,0),Field(1,0,0,0,0,0)], -# [Field(1,0,0,0,0,0),Field(0,0,1,0,0,0),Field(1,3,1,0,0,0),Field(1,2,1,0,0,0),Field(0,0,1,0,0,0),Field(0,0,0,0,0,0),Field(0,1,1,0,0,0),Field(1,0,0,0,0,0),Field(1,1,1,0,0,0),Field(1,1,1,0,0,0)], -# [Field(1,0,0,0,0,0),Field(0,2,0,0,0,0),Field(1,1,0,0,0,0),Field(1,0,1,0,0,0),Field(0,2,1,0,0,0),Field(0,3,0,0,0,0),Field(0,0,0,0,0,0),Field(1,0,0,0,0,0),Field(1,2,1,0,0,0),Field(1,2,1,0,0,0)], -# [Field(1,0,1,0,0,0),Field(0,0,0,0,0,0),Field(1,1,1,0,0,0),Field(1,0,0,0,0,0),Field(0,1,1,0,0,0),Field(0,0,1,0,0,0),Field(0,1,0,0,0,0),Field(1,1,1,0,0,0),Field(1,0,1,0,0,0),Field(1,0,0,0,0,0)]] - - - # ========================================================================================= # no i tutaj mamy główna pÄ™tlÄ™ programu @@ -718,12 +580,12 @@ while running: for event in pygame.event.get(): kbd = pygame.key.get_pressed() mse = pygame.mouse.get_pos() - UIHandler(mse) + UIHandler() eventHandler(kbd, mse) pygame.display.update() # CLOCK.tick(FPS) - #screen.fill((175, 255, 50, 0)) + # screen.fill((175, 255, 50, 0)) # SCREEN.fill((WHITE)) imgWheat = pygame.image.load('img/wheat.png') @@ -745,7 +607,7 @@ while running: else: # a = 1 color = (50, 25, 0, 0) - #colour from the beginning + # colour from the beginning pygame.draw.rect(SCREEN, color, pygame.Rect(50 + 50 * i, 50 + 50 * j, 50, 50)) if T[i][j].plantType == 1: SCREEN.blit(imgWheat, (50 + 50 * i, 50 + 50 * j)) @@ -756,7 +618,6 @@ while running: if T[i][j].plantType == 4: SCREEN.blit(imgTree, (50 + 50 * i, 50 + 50 * j)) - j = j + 1 i = i + 1 @@ -770,34 +631,26 @@ while running: obstacleObjects[obs].draw() # if startNode.state != goalNode.state: - if startNode.x != goalNode[0] or startNode.y != goalNode[1] : + if startNode.x != goalNode[0] or startNode.y != goalNode[1]: for bx in boxObjects: boxObjects[bx].draw() - tmpImg = pygame.transform.rotate(imgPlayer, player.rotation) if player.rotation == 180: tmpImg = pygame.transform.flip(tmpImg, True, True) tmpImg = pygame.transform.flip(tmpImg, True, False) - #player seen at the beginning + # player seen at the beginning SCREEN.blit(tmpImg, (55 + 50 * player.x, 55 + 50 * player.y)) - - - # if Ucelu == False: - # for bx in boxObjects: - # boxObjects[bx].draw() - - - font = pygame.font.SysFont('comicsans', 18) - label = font.render('f- punkt koÅ„cowy, x- drzewa, spacja- uruchomienie', 1, (0, 0, 0)) - label1 = font.render('strzaÅ‚ki-rÄ™czne poruszanie traktorem,', 1, (0, 0, 0)) - label2 = font.render('a- obrót w lewo, d- w prawo, w-ruch naprzód', 1, (0, 0, 0)) - label3 = font.render('b - uruchom A*', 1, (0, 0, 0)) - SCREEN.blit(label, (10, 570)) - SCREEN.blit(label1, (10, 590)) - SCREEN.blit(label2, (10, 610)) + font = pygame.font.SysFont('comicsans', 22) + label = font.render('F - cel | X - drzewo', True, (0, 0, 0)) + label1 = font.render('ARROWS - rÄ™czne poruszanie', True, (0, 0, 0)) + label2 = font.render('A - lewo | D - prawo | W - ruch', True, (0, 0, 0)) + label3 = font.render('SPACE - start BFS | B - start A*', True, (0, 0, 0)) + SCREEN.blit(label, (10, 555)) + SCREEN.blit(label1, (10, 580)) + SCREEN.blit(label2, (10, 605)) SCREEN.blit(label3, (10, 630)) # pygame.display.flip() @@ -807,4 +660,4 @@ while running: # Done! Time to quit. -pygame.quit() \ No newline at end of file +pygame.quit() diff --git a/screen.py b/screen.py index aeaf534..e7ecb42 100644 --- a/screen.py +++ b/screen.py @@ -1,2 +1,2 @@ import pygame -SCREEN = pygame.display.set_mode([600,665]) \ No newline at end of file +SCREEN = pygame.display.set_mode([600, 665])