-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathtrain.py
38 lines (28 loc) · 895 Bytes
/
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
from cgi import print_directory
from configs import cfg
from core.utils.log_util import Logger
from core.data import create_dataloader
from core.nets import create_network
from core.train import create_trainer, create_optimizer
from core.nets import ddp_init, setup_distributed
import logging
def main():
log = Logger()
log.print_config()
if cfg.ddp:
setup_distributed()
model = create_network()
optimizer = create_optimizer(model)
trainer = create_trainer(model, optimizer)
train_loader = create_dataloader('train')
# estimate start epoch
epoch = trainer.iter // len(train_loader) + 1
while True:
if trainer.iter > cfg.train.maxiter:
break
trainer.train(epoch=epoch,
train_dataloader=train_loader)
epoch += 1
trainer.finalize()
if __name__ == '__main__':
main()