| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| from __future__ import absolute_import |
| from __future__ import division |
| from __future__ import print_function |
|
|
| import os |
| import sys |
|
|
| |
| parent_path = os.path.abspath(os.path.join(__file__, *(['..'] * 2))) |
| sys.path.insert(0, parent_path) |
|
|
| |
| import warnings |
| warnings.filterwarnings('ignore') |
|
|
| import paddle |
|
|
| from ppdet.core.workspace import load_config, merge_config |
|
|
| from ppdet.engine import Trainer, TrainerCot, init_parallel_env, set_random_seed, init_fleet_env |
| from ppdet.engine.trainer_ssod import Trainer_DenseTeacher |
|
|
| from ppdet.slim import build_slim_model |
|
|
| from ppdet.utils.cli import ArgsParser, merge_args |
| import ppdet.utils.check as check |
| from ppdet.utils.logger import setup_logger |
| logger = setup_logger('train') |
|
|
|
|
| def parse_args(): |
| parser = ArgsParser() |
| parser.add_argument( |
| "--eval", |
| action='store_true', |
| default=False, |
| help="Whether to perform evaluation in train") |
| parser.add_argument( |
| "-r", "--resume", default=None, help="weights path for resume") |
| parser.add_argument( |
| "--slim_config", |
| default=None, |
| type=str, |
| help="Configuration file of slim method.") |
| parser.add_argument( |
| "--enable_ce", |
| type=bool, |
| default=False, |
| help="If set True, enable continuous evaluation job." |
| "This flag is only used for internal test.") |
| parser.add_argument( |
| "--amp", |
| action='store_true', |
| default=False, |
| help="Enable auto mixed precision training.") |
| parser.add_argument( |
| "--fleet", action='store_true', default=False, help="Use fleet or not") |
| parser.add_argument( |
| "--use_vdl", |
| type=bool, |
| default=False, |
| help="whether to record the data to VisualDL.") |
| parser.add_argument( |
| '--vdl_log_dir', |
| type=str, |
| default="vdl_log_dir/scalar", |
| help='VisualDL logging directory for scalar.') |
| parser.add_argument( |
| "--use_wandb", |
| type=bool, |
| default=False, |
| help="whether to record the data to wandb.") |
| parser.add_argument( |
| '--save_prediction_only', |
| action='store_true', |
| default=False, |
| help='Whether to save the evaluation results only') |
| parser.add_argument( |
| '--profiler_options', |
| type=str, |
| default=None, |
| help="The option of profiler, which should be in " |
| "format \"key1=value1;key2=value2;key3=value3\"." |
| "please see ppdet/utils/profiler.py for detail.") |
| parser.add_argument( |
| '--save_proposals', |
| action='store_true', |
| default=False, |
| help='Whether to save the train proposals') |
| parser.add_argument( |
| '--proposals_path', |
| type=str, |
| default="sniper/proposals.json", |
| help='Train proposals directory') |
| parser.add_argument( |
| "--to_static", |
| action='store_true', |
| default=False, |
| help="Enable dy2st to train.") |
|
|
| args = parser.parse_args() |
| return args |
|
|
|
|
| def run(FLAGS, cfg): |
| |
| if cfg.fleet: |
| init_fleet_env(cfg.get('find_unused_parameters', False)) |
| else: |
| |
| init_parallel_env() |
|
|
| if FLAGS.enable_ce: |
| set_random_seed(0) |
|
|
| |
| ssod_method = cfg.get('ssod_method', None) |
| if ssod_method is not None: |
| if ssod_method == 'DenseTeacher': |
| trainer = Trainer_DenseTeacher(cfg, mode='train') |
| else: |
| raise ValueError( |
| "Semi-Supervised Object Detection only support DenseTeacher now." |
| ) |
| elif cfg.get('use_cot', False): |
| trainer = TrainerCot(cfg, mode='train') |
| else: |
| trainer = Trainer(cfg, mode='train') |
|
|
| |
| if FLAGS.resume is not None: |
| trainer.resume_weights(FLAGS.resume) |
| elif 'pretrain_weights' in cfg and cfg.pretrain_weights: |
| trainer.load_weights(cfg.pretrain_weights) |
|
|
| |
| trainer.train(FLAGS.eval) |
|
|
|
|
| def main(): |
| FLAGS = parse_args() |
| cfg = load_config(FLAGS.config) |
| merge_args(cfg, FLAGS) |
| merge_config(FLAGS.opt) |
|
|
| |
| if 'use_npu' not in cfg: |
| cfg.use_npu = False |
|
|
| |
| if 'use_xpu' not in cfg: |
| cfg.use_xpu = False |
|
|
| if 'use_gpu' not in cfg: |
| cfg.use_gpu = False |
|
|
| |
| if 'use_mlu' not in cfg: |
| cfg.use_mlu = False |
|
|
| if cfg.use_gpu: |
| place = paddle.set_device('gpu') |
| elif cfg.use_npu: |
| place = paddle.set_device('npu') |
| elif cfg.use_xpu: |
| place = paddle.set_device('xpu') |
| elif cfg.use_mlu: |
| place = paddle.set_device('mlu') |
| else: |
| place = paddle.set_device('cpu') |
|
|
| if FLAGS.slim_config: |
| cfg = build_slim_model(cfg, FLAGS.slim_config) |
|
|
| |
| merge_config(FLAGS.opt) |
| check.check_config(cfg) |
| check.check_gpu(cfg.use_gpu) |
| check.check_npu(cfg.use_npu) |
| check.check_xpu(cfg.use_xpu) |
| check.check_mlu(cfg.use_mlu) |
| check.check_version() |
|
|
| run(FLAGS, cfg) |
|
|
|
|
| if __name__ == "__main__": |
| main() |
|
|