-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDL_round2.py
More file actions
50 lines (38 loc) · 2.13 KB
/
DL_round2.py
File metadata and controls
50 lines (38 loc) · 2.13 KB
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
import h5py
from keras.models import load_model
from keras.callbacks import ModelCheckpoint
from dlgo import kerasutil
from dlgo.agent.predict import DeepLearningAgent, load_prediction_agent
from dlgo.data.parallel_processor import GoDataProcessor
from dlgo.encoders.sevenplane import SevenPlaneEncoder
from dlgo.httpfrontend import get_web_app
def main():
go_board_rows, go_board_cols = 19, 19
nb_classes = go_board_rows * go_board_cols
num_games = 5000
encoder = SevenPlaneEncoder((go_board_rows, go_board_cols))
processor = GoDataProcessor(encoder=encoder.name())
generator = processor.load_go_data('train', num_games, use_generator=True)
test_generator = processor.load_go_data('test', num_games, use_generator=True)
# input_shape = (encoder.num_planes, go_board_rows, go_board_cols)
#model_file = h5py.File("checkpointsSeven/deep7_epoch_10.h5", "r")
model = load_model('checkpointsSeven/deep7_run2-20k-train.h5')
model.compile(loss='categorical_crossentropy', optimizer='adadelta', metrics=['accuracy'])
epochs = 5
batch_size = 128
model.fit_generator(generator=generator.generate(batch_size, nb_classes),
epochs=epochs,
steps_per_epoch=generator.get_num_samples() / batch_size,
validation_data=test_generator.generate(batch_size, nb_classes),
validation_steps=test_generator.get_num_samples() / batch_size,
callbacks=[ModelCheckpoint('checkpointsSeven/deep7_training_epoch_{epoch}.h5')])
model.evaluate_generator(generator=test_generator.generate(batch_size, nb_classes),
steps=test_generator.get_num_samples() / batch_size)
deep_learning_bot = DeepLearningAgent(model, encoder)
deep_learning_bot.serialize('checkpointsSeven/deep7-run2-25k.h5')
model_file = h5py.File("checkpointsSeven/deep7-run2-25k.h5", "r")
bot_from_file = load_prediction_agent(model_file)
web_app = get_web_app({'predict': bot_from_file})
web_app.run()
if __name__ == '__main__':
main()