forked from koyeongmin/PINet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
train.py
126 lines (102 loc) · 4.08 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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#############################################################################################################
##
## Source code for training. In this source code, there are initialize part, training part, ...
##
#############################################################################################################
import cv2
import torch
import visdom
import agent
import numpy as np
from data_loader import Generator
from parameters import Parameters
import test
import evaluation
p = Parameters()
###############################################################
##
## Training
##
###############################################################
def Training():
print('Training')
####################################################################
## Hyper parameter
####################################################################
print('Initializing hyper parameter')
vis = visdom.Visdom()
loss_window = vis.line(X=torch.zeros((1,)).cpu(),
Y=torch.zeros((1)).cpu(),
opts=dict(xlabel='epoch',
ylabel='Loss',
title='Training Loss',
legend=['Loss']))
#########################################################################
## Get dataset
#########################################################################
print("Get dataset")
loader = Generator()
##############################
## Get agent and model
##############################
print('Get agent')
if p.model_path == "":
lane_agent = agent.Agent()
else:
lane_agent = agent.Agent()
lane_agent.load_weights(4235, "tensor(0.2127)")
##############################
## Check GPU
##############################
print('Setup GPU mode')
if torch.cuda.is_available():
lane_agent.cuda()
##############################
## Loop for training
##############################
print('Training loop')
step = 0
for epoch in range(p.n_epoch):
lane_agent.training_mode()
for inputs, target_lanes, target_h, test_image in loader.Generate():
#training
print("epoch : " + str(epoch))
print("step : " + str(step))
loss_p = lane_agent.train(inputs, target_lanes, target_h, epoch, lane_agent)
loss_p = loss_p.cpu().data
if step%50 == 0:
vis.line(
X=torch.ones((1, 1)).cpu() * int(step/50),
Y=torch.Tensor([loss_p]).unsqueeze(0).cpu(),
win=loss_window,
update='append')
if step%100 == 0:
lane_agent.save_model(int(step/100), loss_p)
testing(lane_agent, test_image, step, loss_p)
step += 1
#evaluation
if epoch > 0 and epoch%10 == 0:
print("evaluation")
lane_agent.evaluate_mode()
th_list = [0.3, 0.5, 0.7]
lane_agent.save_model(int(step/100), loss_p)
for th in th_list:
print("generate result")
print(th)
test.evaluation(loader, lane_agent, thresh = th, name="test_result_"+str(epoch)+"_"+str(th)+".json")
for th in th_list:
print("compute score")
print(th)
with open("eval_result_"+str(th)+"_.txt", 'a') as make_file:
make_file.write( "epoch : " + str(epoch) + " loss : " + str(loss_p.cpu().data) )
make_file.write(evaluation.LaneEval.bench_one_submit("test_result_"+str(epoch)+"_"+str(th)+".json", "test_label.json"))
make_file.write("\n")
if int(step)>700000:
break
def testing(lane_agent, test_image, step, loss):
lane_agent.evaluate_mode()
_, _, ti = test.test(lane_agent, np.array([test_image]))
cv2.imwrite('test_result/result_'+str(step)+'_'+str(loss)+'.png', ti[0])
lane_agent.training_mode()
if __name__ == '__main__':
Training()