-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathtrain.py
104 lines (79 loc) · 3.62 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
'''
@author LeslieZhao
@date 20221221
'''
import os
import argparse
from trainer.AlignTrainer import AlignTrainer
from trainer.BlendTrainer import BlendTrainer
# from trainer.FinetuneTrainer import FineTuneTrainer
import torch.distributed as dist
from utils.utils import setup_seed,get_data_loader,merge_args
from model.AlignModule.config import Params as AlignParams
from model.BlendModule.config import Params as BlendParams
# torch.multiprocessing.set_start_method('spawn')
parser = argparse.ArgumentParser(description="HeadSwap")
#---------train set-------------------------------------
parser.add_argument('--model',default="align",help='')
parser.add_argument('--isTrain',action="store_false",help='')
parser.add_argument('--dist',action="store_false",help='')
parser.add_argument('--apply_begin_it',action="store_false",help='')
parser.add_argument('--batch_size',default=16,type=int)
parser.add_argument('--seed',default=10,type=int)
parser.add_argument('--eval',default=1,type=int,help='whether use eval')
parser.add_argument('--nDataLoaderThread',default=5,type=int,help='Num of loader threads')
parser.add_argument('--print_interval',default=100,type=int)
parser.add_argument('--test_interval',default=100,type=int,help='Test and save every [test_intervaal] epochs')
parser.add_argument('--save_interval',default=100,type=int,help='save model interval')
parser.add_argument('--stop_interval',default=20,type=int)
parser.add_argument('--begin_it',default=0,type=int,help='begin epoch')
parser.add_argument('--mx_data_length',default=100,type=int,help='max data length')
parser.add_argument('--max_epoch',default=10000,type=int)
parser.add_argument('--early_stop',action="store_true",help='')
parser.add_argument('--scratch',action="store_true",help='')
#---------path set--------------------------------------
parser.add_argument('--checkpoint_path',default='checkpoint',type=str)
parser.add_argument('--pretrain_path',default=None,type=str)
# ------optimizer set--------------------------------------
parser.add_argument('--lr',default=0.002,type=float,help="Learning rate")
parser.add_argument(
'--local_rank',
type=int,
default=0,
help='Local rank passed from distributed launcher'
)
args = parser.parse_args()
def train_net(args):
train_loader,test_loader,mx_length = get_data_loader(args)
args.mx_data_length = mx_length
if args.model == 'align':
trainer = AlignTrainer(args)
elif args.model == 'blend':
trainer = BlendTrainer(args)
# elif args.model == 'finetune':
# trainer = FineTuneTrainer(args)
trainer.train_network(train_loader,test_loader)
if __name__ == "__main__":
args = parser.parse_args()
if args.model == 'align' :
params = AlignParams()
elif args.model == 'blend':
params = BlendParams()
args = merge_args(args,params)
if args.dist:
dist.init_process_group(backend="nccl") # backbend='nccl'
dist.barrier() # 用于同步训练
args.world_size = dist.get_world_size() # 一共有几个节点
args.rank = dist.get_rank() # 当前节点编号
else:
args.world_size = 1
args.rank = 0
setup_seed(args.seed+args.rank)
print(args)
args.checkpoint_path = os.path.join(args.checkpoint_path,args.name)
print("local_rank %d | rank %d | world_size: %d"%(int(os.environ.get('LOCAL_RANK','0')),args.rank,args.world_size))
if args.rank == 0 :
if not os.path.exists(args.checkpoint_path):
os.makedirs(args.checkpoint_path)
print("make dir: ",args.checkpoint_path)
train_net(args)