-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathmain.py
72 lines (61 loc) · 2.76 KB
/
main.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
# -*- coding: utf-8 -*-
# @Author: Song Dejia
# @Date: 2018-10-21 20:47:07
# @Last Modified by: Song Dejia
# @Last Modified time: 2018-10-23 19:00:38
import torch
import torch.backends.cudnn as cudnn
import argparse
import sys
import os
from utils.util import *
from utils.dataset import *
from model.deeplab import DeepLabv3_plus
from train import train_deeplab_v3_plus
from test import evaluation
def main():
args = parse_parameters()
print('*'*50)
print('DeepLab_v3_plus <==> Prepare for Dataset <==> Begin')
train_dataloader = prepare_for_train_dataloader(args.dataroot, bs_train=args.train_batchsize_per_gpu * args.gpu, shuffle=True, num_workers=args.j, check_dataloader=args.check_dataloader)
val_dataloader = prepare_for_val_dataloader(args.dataroot, bs_val=args.test_batchsize, shuffle=False, num_workers=args.j)
print('DeepLab_v3_plus <==> Prepare for Dataset <==> Done\n\n')
sys.exit(0)
# network
print('*'*50)
print('DeepLab_v3_plus <==> Prepare for Network <==> Begin')
net = DeepLabv3_plus(nInputChannels=3, n_classes=21, os=16, pretrained=True, _print=True)
optimizer = torch.optim.SGD(net.parameters(), lr=args.init_lr, momentum=args.momentum, weight_decay = args.weight_decay)
criterion = cross_entropy2d
net = nn.DataParallel(net, device_ids=range(args.gpu)) if args.gpu else net
net = net.cuda()
cudnn.benchmark = True
print('DeepLab_v3_plus <==> Resume Network checkpoint <==> Begin')
if args.resume:
if os.path.isfile(args.resume):
checkpoint = torch.load(args.resume)
start_epoch = checkpoint['epoch'] + 1
net.load_state_dict(checkpoint['state_dict'])
optimizer.load_state_dict(checkpoint['optimizer'])
print('DeepLab_v3_plus <==> Resume Network checkpoint, next epoch:{}<==> Begin'.format(start_epoch))
else:
start_epoch = 0
print('DeepLab_v3_plus <==> Prepare for Network <==> Done\n\n')
global_step = 0
running_loss_tr = 0.0
print('*'*50)
for epoch in range(start_epoch, args.max_epoches):
# train
lr, optimizer = adjust_learning_rate(args.init_lr, optimizer, epoch, args.max_epoches, gamma = 0.9, decay_step = args.decay_every_epoches)
train_deeplab_v3_plus(train_dataloader, net, criterion, optimizer, epoch, global_step, running_loss_tr)
if epoch % args.test_epoches == 0 :
evaluation(val_dataloader, net, epoch, save_dir=args.log_test_dir)
if epoch % args.save_weights_epoches == 0 :
save_checkpoint({
'epoch': epoch,
'state_dict': net.state_dict(),
'optimizer' : optimizer.state_dict(),
},
weights_dir = args.weights)
if __name__ == '__main__':
main()