-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathtrain.py
executable file
·78 lines (64 loc) · 3.01 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
from utils.config import cfg # isort: split
import os
import time
from tensorboardX import SummaryWriter
from tqdm import tqdm
from utils.datasets import create_dataloader
from utils.earlystop import EarlyStopping
from utils.eval import get_val_cfg, validate
from utils.trainer import Trainer
from utils.utils import Logger
if __name__ == "__main__":
val_cfg = get_val_cfg(cfg, split="val", copy=True)
cfg.dataset_root = os.path.join(cfg.dataset_root, "train")
data_loader = create_dataloader(cfg)
dataset_size = len(data_loader)
log = Logger()
log.open(cfg.logs_path, mode="a")
log.write("Num of training images = %d\n" % (dataset_size * cfg.batch_size))
log.write("Config:\n" + str(cfg.to_dict()) + "\n")
train_writer = SummaryWriter(os.path.join(cfg.exp_dir, "train"))
val_writer = SummaryWriter(os.path.join(cfg.exp_dir, "val"))
trainer = Trainer(cfg)
early_stopping = EarlyStopping(patience=cfg.earlystop_epoch, delta=-0.001, verbose=True)
for epoch in range(cfg.nepoch):
epoch_start_time = time.time()
iter_data_time = time.time()
epoch_iter = 0
for data in tqdm(data_loader, dynamic_ncols=True):
trainer.total_steps += 1
epoch_iter += cfg.batch_size
trainer.set_input(data)
trainer.optimize_parameters()
# if trainer.total_steps % cfg.loss_freq == 0:
# log.write(f"Train loss: {trainer.loss} at step: {trainer.total_steps}\n")
train_writer.add_scalar("loss", trainer.loss, trainer.total_steps)
if trainer.total_steps % cfg.save_latest_freq == 0:
log.write(
"saving the latest model %s (epoch %d, model.total_steps %d)\n"
% (cfg.exp_name, epoch, trainer.total_steps)
)
trainer.save_networks("latest")
if epoch % cfg.save_epoch_freq == 0:
log.write("saving the model at the end of epoch %d, iters %d\n" % (epoch, trainer.total_steps))
trainer.save_networks("latest")
trainer.save_networks(epoch)
# Validation
trainer.eval()
val_results = validate(trainer.model, val_cfg)
val_writer.add_scalar("AP", val_results["AP"], trainer.total_steps)
val_writer.add_scalar("ACC", val_results["ACC"], trainer.total_steps)
log.write(f"(Val @ epoch {epoch}) AP: {val_results['AP']}; ACC: {val_results['ACC']}\n")
if cfg.earlystop:
early_stopping(val_results["ACC"], trainer)
if early_stopping.early_stop:
if trainer.adjust_learning_rate():
log.write("Learning rate dropped by 10, continue training...\n")
early_stopping = EarlyStopping(patience=cfg.earlystop_epoch, delta=-0.002, verbose=True)
else:
log.write("Early stopping.\n")
break
if cfg.warmup:
# print(trainer.scheduler.get_lr()[0])
trainer.scheduler.step()
trainer.train()