2021-05-15 22:41:07 +02:00
import matplotlib . image as pltimg
import matplotlib . pyplot as plt
import os
import pandas
2021-05-19 15:04:17 +02:00
import pickle
2021-05-15 22:41:07 +02:00
import pydotplus
from sklearn import tree
from sklearn . tree import DecisionTreeClassifier
2021-05-31 18:16:14 +02:00
def make_decision ( amount_of_seeds , collected_plants , fertilizer , fuel , tree , water_level ) : #zwraca decyzję o powrocie do stacji (0 : NIE, 1 : TAK)
2021-05-31 17:10:14 +02:00
decision = tree . predict ( [ [ amount_of_seeds , collected_plants , fertilizer , fuel , water_level ] ] ) #podejmij decyzję na podstawie aktualnych parametrów wózka o powrocie do stacji lub nie
return decision
2021-05-16 15:36:53 +02:00
def treelearn ( ) : #zwraca utworzone drzewo decyzyjne
2021-05-31 17:10:14 +02:00
if os . path . exists ( " resources/decision_tree/tree.pkl " ) : #jeżeli drzewo jest zapisane w pliku to odczytaj
dtree = pickle . load ( open ( os . path . join ( ' resources/decision_tree ' , " tree.pkl " ) , " rb " ) )
2021-05-19 15:04:17 +02:00
else : #w przeciwnym razie utwórz drzewo od początku i zapisz do pliku
2021-05-31 17:10:14 +02:00
df = pandas . read_csv ( os . path . join ( ' resources/decision_tree ' , ' data.csv ' ) ) #czytanie danych do nauki drzewa z pliku .csv
2021-05-19 15:04:17 +02:00
features = [ ' amount of seeds ' , ' collected plants ' , ' fertilizer ' , ' fuel ' , ' water level ' ]
x = df [ features ] #wczytanie atrybutów, z których ma się uczyć drzewo
y = df [ ' back to station ' ] #podjęte decyzje
dtree = DecisionTreeClassifier ( ) #klasyfikuje drzewo
dtree = dtree . fit ( x , y ) #uczy drzewo
2021-05-31 17:10:14 +02:00
pickle . dump ( dtree , open ( os . path . join ( ' resources/decision_tree ' , " tree.pkl " ) , " wb " ) )
2021-05-19 15:04:17 +02:00
data = tree . export_graphviz ( dtree , out_file = None , feature_names = features )
graph = pydotplus . graph_from_dot_data ( data )
2021-05-31 17:10:14 +02:00
graph . write_png ( os . path . join ( ' resources/decision_tree ' , ' mytree.png ' ) )
img = pltimg . imread ( os . path . join ( ' resources/decision_tree ' , ' mytree.png ' ) )
2021-05-19 15:04:17 +02:00
imgplot = plt . imshow ( img )
plt . show ( ) #wyświetl drzewo decyzyjne
2021-05-31 17:10:14 +02:00
return dtree