| _base_ = [ |
| '/home/liuziyuan/proj/rmcd-kd/configs/_base_/models/cgnet.py', |
| '/home/liuziyuan/proj/rmcd-kd/configs/common/train_medium_512x512_100k_cgwx.py'] |
|
|
| dataset_type = 'LEVIR_CD_Dataset' |
| data_root = '/nas/datasets/lzy/RS-ChangeDetection/CGWX' |
|
|
| crop_size = (512, 512) |
|
|
| train_pipeline = [ |
| dict(type='MultiImgLoadImageFromFile'), |
| dict(type='MultiImgLoadAnnotations'), |
| dict(type='MultiImgRandomRotate', prob=0.5, degree=180), |
| dict(type='MultiImgRandomCrop', crop_size=crop_size, cat_max_ratio=0.75), |
| dict(type='MultiImgRandomFlip', prob=0.5, direction='horizontal'), |
| dict(type='MultiImgRandomFlip', prob=0.5, direction='vertical'), |
| |
| dict( |
| type='MultiImgPhotoMetricDistortion', |
| brightness_delta=10, |
| contrast_range=(0.8, 1.2), |
| saturation_range=(0.8, 1.2), |
| hue_delta=10), |
| dict(type='MultiImgPackSegInputs') |
| ] |
| test_pipeline = [ |
| dict(type='MultiImgLoadImageFromFile'), |
| dict(type='MultiImgResize', scale=(512, 512), keep_ratio=True), |
| |
| |
| dict(type='MultiImgLoadAnnotations'), |
| dict(type='MultiImgPackSegInputs') |
| ] |
|
|
| img_ratios = [0.75, 1.0, 1.25] |
|
|
| tta_pipeline = [ |
| dict(type='MultiImgLoadImageFromFile', backend_args=None), |
| dict( |
| type='TestTimeAug', |
| transforms=[ |
| [ |
| dict(type='MultiImgResize', scale_factor=r, keep_ratio=True) |
| for r in img_ratios |
| ], |
| [ |
| dict(type='MultiImgRandomFlip', prob=0., direction='horizontal'), |
| dict(type='MultiImgRandomFlip', prob=1., direction='horizontal') |
| ], |
| [dict(type='MultiImgLoadAnnotations')], |
| [dict(type='MultiImgPackSegInputs')] |
| ]) |
| ] |
|
|
| |
| optimizer = dict( |
| type='AdamW', |
| lr=5e-4, |
| betas=(0.9, 0.999), |
| weight_decay=0.0025) |
|
|
| optim_wrapper = dict( |
| _delete_=True, |
| type='OptimWrapper', |
| optimizer=optimizer) |
|
|
| crop_size = (512, 512) |
|
|
| model = dict( |
| test_cfg=dict(mode='slide', crop_size=crop_size, stride=(crop_size[0]//2, crop_size[1]//2)), |
| ) |
|
|
|
|
| param_scheduler = [ |
| dict( |
| type='LinearLR', start_factor=1e-6, by_epoch=False, begin=0, end=1000), |
| dict( |
| type='PolyLR', |
| power=1.0, |
| begin=1000, |
| end=200000, |
| eta_min=0.0, |
| by_epoch=False, |
| ) |
| ] |
| |
| train_cfg = dict(type='IterBasedTrainLoop', max_iters=200000, val_interval=1000) |
| val_cfg = dict(type='ValLoop') |
| test_cfg = dict(type='TestLoop') |
| default_hooks = dict( |
| timer=dict(type='IterTimerHook'), |
| logger=dict(type='LoggerHook', interval=100, log_metric_by_epoch=False), |
| param_scheduler=dict(type='ParamSchedulerHook'), |
| checkpoint=dict(type='CheckpointHook', by_epoch=False, interval=1000, |
| save_best='mIoU'), |
| sampler_seed=dict(type='DistSamplerSeedHook'), |
| visualization=dict(type='CDVisualizationHook', interval=1, |
| img_shape=(512, 512, 3))) |