-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathtrain.py
73 lines (57 loc) · 2.52 KB
/
train.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
"""
Walk-Assistant : Recognizing sidewalk for the visually impaired
Copyright (C) 2018 Yoongi Kim ([email protected])
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
"""
print("""
Walk-Assistant Copyright (C) 2018 Yoongi Kim
This program comes with ABSOLUTELY NO WARRANTY.
This is free software, and you are welcome to redistribute it
under certain conditions.
""")
import tensorflow as tf
from model import MyModel
import glob
from generator import Generator
from keras.callbacks import TensorBoard, ModelCheckpoint
PATH = "data/frames"
TRAIN_LABEL = "data/label.txt"
VAILD_LABEL = "data/valid.txt"
BATCH_SIZE = 1
HEIGHT = 720
WIDTH = 1280
KERNEL = 80
STRIDE = 80
TILE_ROW = int((HEIGHT-KERNEL)/STRIDE+1)
TILE_COL = int((WIDTH-KERNEL)/STRIDE+1)
print('Load last trained model? (y/n)')
answer = input()
load = True
if answer == 'n':
load = False
print('Building new model...')
else:
load = True
print('Loading model...')
my_model = MyModel(load, HEIGHT, WIDTH, KERNEL, STRIDE, lr=1e-4, model_name='main')
train_gen = Generator(PATH, TRAIN_LABEL, tile_row=TILE_ROW, tile_col=TILE_COL, batch_size=BATCH_SIZE)
valid_gen = Generator(PATH, TRAIN_LABEL, tile_row=TILE_ROW, tile_col=TILE_COL, batch_size=BATCH_SIZE)
checkpoint_path = 'models/main/model.{epoch:02d}-{val_acc:.2f}.h5'
checkpoint = ModelCheckpoint(checkpoint_path, monitor='val_acc', save_best_only=False, mode='auto', save_weights_only=False)
tb = TensorBoard(log_dir='./logs', histogram_freq=0, batch_size=BATCH_SIZE, write_graph=True, write_grads=True, write_images=True)
my_model.model.fit_generator(train_gen.generator(),
steps_per_epoch=len(train_gen.files)//BATCH_SIZE,
epochs=100,
callbacks=[checkpoint, tb],
initial_epoch=my_model.epoch,
validation_data=valid_gen.generator(),
validation_steps=len(valid_gen.files)//BATCH_SIZE)