Shortcuts

base_liif 源代码

# Copyright (c) OpenMMLab. All rights reserved.
from mmengine.dataset import DefaultSampler, InfiniteSampler
from mmengine.hooks import (CheckpointHook, DistSamplerSeedHook, IterTimerHook,
                            LoggerHook, ParamSchedulerHook)
from mmengine.optim import MultiStepLR, OptimWrapper
from mmengine.runner import IterBasedTrainLoop

from mmagic.datasets.transforms import (Flip, GenerateCoordinateAndCell,
                                        LoadImageFromFile, PackInputs,
                                        RandomDownSampling, RandomTransposeHW)
from mmagic.engine.runner import MultiValLoop
from mmagic.evaluation import MAE, PSNR, SSIM, Evaluator

[文档]_base_ = '../default_runtime.py'
[文档]work_dir = './work_dirs/liif'
[文档]save_dir = './work_dirs'
scale_min, scale_max = 1, 4
[文档]scale_test = 4
[文档]train_pipeline = [ dict( type=LoadImageFromFile, key='gt', color_type='color', channel_order='rgb', imdecode_backend='cv2'), dict( type=RandomDownSampling, scale_min=scale_min, scale_max=scale_max, patch_size=48), dict( type=Flip, keys=['img', 'gt'], flip_ratio=0.5, direction='horizontal'), dict(type=Flip, keys=['img', 'gt'], flip_ratio=0.5, direction='vertical'), dict(type=RandomTransposeHW, keys=['img', 'gt'], transpose_ratio=0.5), dict(type=GenerateCoordinateAndCell, sample_quantity=2304), dict(type=PackInputs)
]
[文档]val_pipeline = [ dict( type=LoadImageFromFile, key='gt', color_type='color', channel_order='rgb', imdecode_backend='cv2'), dict(type=RandomDownSampling, scale_min=scale_max, scale_max=scale_max), dict(type=GenerateCoordinateAndCell, reshape_gt=False), dict(type=PackInputs)
] # test_pipeline = [ # dict( # type=LoadImageFromFile, # key='gt', # color_type='color', # channel_order='rgb', # imdecode_backend='cv2'), # dict( # type=LoadImageFromFile, # key='img', # color_type='color', # channel_order='rgb', # imdecode_backend='cv2'), # dict(type=GenerateCoordinateAndCell, scale=scale_test, # reshape_gt=False), # dict(type=PackInputs) # ] # dataset settings
[文档]dataset_type = 'BasicImageDataset'
[文档]data_root = 'data'
[文档]train_dataloader = dict( num_workers=8, batch_size=16, persistent_workers=False, sampler=dict(type=InfiniteSampler, shuffle=True), dataset=dict( type=dataset_type, ann_file='meta_info_DIV2K800sub_GT.txt', metainfo=dict(dataset_type='div2k', task_name='sisr'), data_root=data_root + '/DIV2K', data_prefix=dict(gt='DIV2K_train_HR_sub'), pipeline=train_pipeline))
[文档]val_dataloader = dict( num_workers=4, persistent_workers=False, drop_last=False, sampler=dict(type=DefaultSampler, shuffle=False), dataset=dict( type=dataset_type, metainfo=dict(dataset_type='set5', task_name='sisr'), data_root=data_root + '/Set5', data_prefix=dict(img='LRbicx4', gt='GTmod12'), pipeline=val_pipeline))
[文档]val_evaluator = dict( type=Evaluator, metrics=[ dict(type=MAE), dict(type=PSNR, crop_border=scale_max), dict(type=SSIM, crop_border=scale_max),
])
[文档]train_cfg = dict( type=IterBasedTrainLoop, max_iters=1_000_000, val_interval=3000)
[文档]val_cfg = dict(type=MultiValLoop)
# optimizer
[文档]optim_wrapper = dict( constructor='DefaultOptimWrapperConstructor', type=OptimWrapper, optimizer=dict(type='Adam', lr=1e-4))
# learning policy
[文档]param_scheduler = dict( type=MultiStepLR, by_epoch=False, milestones=[200_000, 400_000, 600_000, 800_000], gamma=0.5)
[文档]default_hooks = dict( checkpoint=dict( type=CheckpointHook, interval=3000, save_optimizer=True, by_epoch=False, out_dir=save_dir, ), timer=dict(type=IterTimerHook), logger=dict(type=LoggerHook, interval=100), param_scheduler=dict(type=ParamSchedulerHook), sampler_seed=dict(type=DistSamplerSeedHook),
)