-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrun_training.py
82 lines (62 loc) · 2.5 KB
/
run_training.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
"""
Runs training of experiment
Usage: run_training.py --cfg=<config_file_path> --o=<output_dir> [--device=<execution_device>] [--experiment_name=<name>] [--seed=<random_seed>]
Options:
--cfg=<config_file_path> Path to experiment configuration file
--o=<output_directory> Path to experiments output directory
--device=<gpus_ids> Ids of GPUs to run training on, if None runs on CPU
--experiment_name=<name> Custom naming for subdirectory where experiment outputs are saved
--seed=<random_seed> Random seed to use for experiment initialization
"""
import os
from docopt import docopt
import pytorch_lightning as pl
from src.deep_reflectance_fusion import build_experiment, build_callback
from src.deep_reflectance_fusion.experiments import Logger
from src.utils import load_yaml
def main(args, cfg):
# Set seed for reproducibility
set_seed(args, cfg)
# Build experiment
experiment = build_experiment(cfg)
# Build logging and callbacks
logger = make_logger(args)
model_checkpoint = make_model_checkpoint(cfg['model_checkpoint'])
early_stopping = build_callback(cfg['early_stopping'])
# Instantiate trainer instance
params = {'logger': logger,
'early_stop_callback': early_stopping,
'checkpoint_callback': model_checkpoint,
'resume_from_checkpoint': cfg['experiment']['chkpt'],
'precision': cfg['experiment']['precision'],
'max_epochs': cfg['experiment']['max_epochs'],
'gpus': args['--device']}
trainer = pl.Trainer(**params)
# Run training
trainer.fit(experiment)
def set_seed(args, cfg):
"""Sets random seed for reproducibility
"""
seed = int(args["--seed"]) if args["--seed"] else cfg['experiment']['seed']
pl.seed_everything(seed)
def make_logger(args):
"""Build logger instance pointing to specified output directory
"""
logger_kwargs = {'save_dir': os.path.dirname(args['--o']),
'name': os.path.basename(args['--o'])}
if args['--experiment_name']:
logger_kwargs.update({'version': args['--experiment_name']})
logger = Logger(**logger_kwargs)
return logger
def make_model_checkpoint(cfg):
"""Build model checkpointing callback
"""
model_checkpoint = pl.callbacks.ModelCheckpoint(**cfg)
return model_checkpoint
if __name__ == "__main__":
# Read input args
args = docopt(__doc__)
# Load configuration file
cfg = load_yaml(args["--cfg"])
# Run training
main(args, cfg)