-
-
Notifications
You must be signed in to change notification settings - Fork 215
/
Copy pathtrain_ocr_layer.py
executable file
·46 lines (34 loc) · 1.44 KB
/
train_ocr_layer.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
#!/usr/bin/python
import text
import layer
import letter
# layer.clear_tensorboard() # Get rid of old runs
data = letter.batch(letter.Target.letter, batch_size=10)
# data = text.batch(text.Target.word, batch_size=10)
input_width, output_width=data.shape[0],data.shape[1]
# x,y = next(data)
# print(np.array(x).shape)
# print(np.array(y).shape)
# # exit(0)
# learning_rate = 0.03 # divergence even on overfit
# learning_rate = 0.003 # quicker overfit
learning_rate = 0.0003
training_steps = 500000
batch_size = 10
# size = text.canvas_size
size = letter.max_size
def denseConv(net):
# type: (layer.net) -> None
print("Building dense-net")
net.reshape(shape=[-1, size, size, letter.color_channels]) # Reshape input picture
net.buildDenseConv(nBlocks=1)
""" Baseline tests to see that your model doesn't have any bugs and can learn small test sites without efforts """
# net = layer.net(layer.baseline, input_width=size, output_width=nClasses, learning_rate=learning_rate)
# net.train(data=data, test_step=1000) # run
""" here comes the real network """
net = layer.net(denseConv, input_width=size, output_width=96, learning_rate=learning_rate)
# net.train(data=data,steps=50000,dropout=0.6,display_step=1,test_step=1) # debug
# net.train(data=data, steps=training_steps,dropout=0.6,display_step=5,test_step=20) # test
net.train(data=data, dropout=.6, display_step=5, test_step=100) # run resume
# net.predict() # nil=random
# net.generate(3) # nil=random