-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathtrain_voc.py
executable file
·115 lines (87 loc) · 3.83 KB
/
train_voc.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
from model.fcos import FCOSDetector
import torch
from dataset.VOC_dataset import VOCDataset
import math, time
from dataset.augment import Transforms
import os
import numpy as np
import random
import torch.backends.cudnn as cudnn
import argparse
parser = argparse.ArgumentParser()
parser.add_argument("--epochs", type=int, default=30, help="number of epochs")
parser.add_argument("--batch_size", type=int, default=16, help="size of each image batch")
parser.add_argument("--n_cpu", type=int, default=4, help="number of cpu threads to use during batch generation")
parser.add_argument("--n_gpu", type=str, default='0,1', help="number of cpu threads to use during batch generation")
opt = parser.parse_args()
os.environ["CUDA_VISIBLE_DEVICES"] = opt.n_gpu
torch.manual_seed(0)
torch.cuda.manual_seed(0)
torch.cuda.manual_seed_all(0)
np.random.seed(0)
cudnn.benchmark = False
cudnn.deterministic = True
random.seed(0)
transform = Transforms()
train_dataset = VOCDataset(root_dir='/Users/VOC0712',resize_size=[800,1333],
split='trainval',use_difficult=False,is_train=True,augment=transform)
model = FCOSDetector(mode="training").cuda()
model = torch.nn.DataParallel(model)
# model.load_state_dict(torch.load('/mnt/cephfs_new_wj/vc/zhangzhenghao/FCOS.Pytorch/output1/model_6.pth'))
BATCH_SIZE = opt.batch_size
EPOCHS = opt.epochs
#WARMPUP_STEPS_RATIO = 0.12
train_loader = torch.utils.data.DataLoader(train_dataset, batch_size=BATCH_SIZE, shuffle=True,
collate_fn=train_dataset.collate_fn,
num_workers=opt.n_cpu, worker_init_fn=np.random.seed(0))
print("total_images : {}".format(len(train_dataset)))
steps_per_epoch = len(train_dataset) // BATCH_SIZE
TOTAL_STEPS = steps_per_epoch * EPOCHS
WARMPUP_STEPS = 501
GLOBAL_STEPS = 1
LR_INIT = 2e-3
LR_END = 2e-5
optimizer = torch.optim.SGD(model.parameters(),lr =LR_INIT,momentum=0.9,weight_decay=0.0001)
# def lr_func():
# if GLOBAL_STEPS < WARMPUP_STEPS:
# lr = GLOBAL_STEPS / WARMPUP_STEPS * LR_INIT
# else:
# lr = LR_END + 0.5 * (LR_INIT - LR_END) * (
# (1 + math.cos((GLOBAL_STEPS - WARMPUP_STEPS) / (TOTAL_STEPS - WARMPUP_STEPS) * math.pi))
# )
# return float(lr)
model.train()
for epoch in range(EPOCHS):
for epoch_step, data in enumerate(train_loader):
batch_imgs, batch_boxes, batch_classes = data
batch_imgs = batch_imgs.cuda()
batch_boxes = batch_boxes.cuda()
batch_classes = batch_classes.cuda()
#lr = lr_func()
if GLOBAL_STEPS < WARMPUP_STEPS:
lr = float(GLOBAL_STEPS / WARMPUP_STEPS * LR_INIT)
for param in optimizer.param_groups:
param['lr'] = lr
if GLOBAL_STEPS == 20001:
lr = LR_INIT * 0.1
for param in optimizer.param_groups:
param['lr'] = lr
if GLOBAL_STEPS == 27001:
lr = LR_INIT * 0.01
for param in optimizer.param_groups:
param['lr'] = lr
start_time = time.time()
optimizer.zero_grad()
losses = model([batch_imgs, batch_boxes, batch_classes])
loss = losses[-1]
loss.mean().backward()
optimizer.step()
end_time = time.time()
cost_time = int((end_time - start_time) * 1000)
print(
"global_steps:%d epoch:%d steps:%d/%d cls_loss:%.4f cnt_loss:%.4f reg_loss:%.4f cost_time:%dms lr=%.4e total_loss:%.4f" % \
(GLOBAL_STEPS, epoch + 1, epoch_step + 1, steps_per_epoch, losses[0].mean(), losses[1].mean(),
losses[2].mean(), cost_time, lr, loss.mean()))
GLOBAL_STEPS += 1
torch.save(model.state_dict(),
"./checkpoint/model_{}.pth".format(epoch + 1))