Improving model, fix plate prediction

This commit is contained in:
s450026 2020-05-26 15:00:29 +02:00
parent 1f9ee15a72
commit b8f9b15692
44 changed files with 15 additions and 7 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.4 KiB

After

Width:  |  Height:  |  Size: 106 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 41 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 106 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 360 KiB

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.5 KiB

After

Width:  |  Height:  |  Size: 41 KiB

View File

@ -22,14 +22,21 @@ current_path = os.path.dirname(__file__)
relative_path = os.path.join(current_path, 'Data/') relative_path = os.path.join(current_path, 'Data/')
DATADIR = relative_path + 'LearningData' DATADIR = relative_path + 'LearningData'
CATEGORIES = ['Full', 'Empty'] CATEGORIES = ['Full', 'Empty'] # labels
IMG_SIZE = 70 # specify on which size we want to transform the photos for example 50x50px IMG_SIZE = 150 # specify on which size we want to transform the photos for example 50x50px
NAME = 'plate-cnn-64x2-{}'.format(int(time.time())) NAME = 'plate-cnn-64x2-{}'.format(int(time.time()))
training_data = [] training_data = []
X = [] # feature set X = [] # feature set
y = [] # label set y = [] # label set
'''
layer size | conv leyer |
64 | 1 | loss: 0.0443 - accuracy: 0.9942 - val_loss: 0.3614 - val_accuracy: 0.7692
64 | 2 | loss: 0.0931 - accuracy: 0.9625 - val_loss: 0.4772 - val_accuracy: 0.8462
64 | 3 |
'''
def create_training_data(): def create_training_data():
for category in CATEGORIES: for category in CATEGORIES:
@ -115,7 +122,7 @@ def creat_model():
model.fit(X, y, batch_size=32, epochs=10, validation_split=0.1, callbacks=[tenserboard]) model.fit(X, y, batch_size=32, epochs=10, validation_split=0.1, callbacks=[tenserboard])
model.save(relative_path + 'SavedModels/plate-64x2-cnn.model') model.save(relative_path + 'SavedModels/{}.model'.format(NAME))
def use_model_to_predict(name): def use_model_to_predict(name):
@ -128,7 +135,7 @@ def use_model_to_predict(name):
plt.show() plt.show()
return new_array.reshape(-1, IMG_SIZE, IMG_SIZE, 1) return new_array.reshape(-1, IMG_SIZE, IMG_SIZE, 1)
model = tf.keras.models.load_model(relative_path + 'SavedModels/plate-64x2-cnn.model') model = tf.keras.models.load_model(relative_path + 'SavedModels/plate-cnn-64x1-1590497461.model')
prediction = model.predict([prepare(relative_path + 'TestData/' + name + '.jpg')]) prediction = model.predict([prepare(relative_path + 'TestData/' + name + '.jpg')])
print(prediction) print(prediction)
@ -139,7 +146,7 @@ def use_model_to_predict(name):
def text_speech(font: str, size: int, text: str, color, background, x, y, bold: bool, bubble: bool, screen): def text_speech(font: str, size: int, text: str, color, background, x, y, bold: bool, bubble: bool, screen):
global textRect global textRect
font = pygame.font.SysFont(None, size) font = pygame.font.SysFont(None, size)
#font = pygame.font.Font(font, size) # font = pygame.font.Font(font, size)
font.set_bold(bold) font.set_bold(bold)
textSurf = font.render(text, True, color).convert_alpha() textSurf = font.render(text, True, color).convert_alpha()
if bubble: if bubble:
@ -155,6 +162,7 @@ def text_speech(font: str, size: int, text: str, color, background, x, y, bold:
textRect.center = (x, y) textRect.center = (x, y)
screen.blit(textSurf, textRect) screen.blit(textSurf, textRect)
# save_dataset() # save_dataset()
# use_model_to_predict('test-full-5') #use_model_to_predict('test-0')
# creat_model() creat_model()