Source code for base_tof
# 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 LoadImageFromFile, PackInputs
from mmagic.engine.runner import MultiTestLoop, MultiValLoop
from mmagic.evaluation import MAE, PSNR, SSIM
[docs]train_pipeline = [
dict(
type=LoadImageFromFile,
key='img',
channel_order='rgb',
imdecode_backend='pillow'),
dict(
type=LoadImageFromFile,
key='gt',
channel_order='rgb',
imdecode_backend='pillow'),
dict(type=PackInputs)
]
[docs]demo_pipeline = [
dict(
type=LoadImageFromFile,
key='img',
channel_order='rgb',
imdecode_backend='pillow'),
dict(type=PackInputs)
]
# dataset settings
[docs]train_dataloader = dict(
num_workers=4,
persistent_workers=False,
sampler=dict(type=InfiniteSampler, shuffle=True),
dataset=dict(
type=train_dataset_type,
ann_file='tri_trainlist.txt',
metainfo=dict(dataset_type='vimeo90k', task_name='vfi'),
data_root=data_root,
data_prefix=dict(img='sequences', gt='sequences'),
pipeline=train_pipeline,
depth=2,
load_frames_list=dict(img=['im1.png', 'im3.png'], gt=['im2.png'])))
[docs]val_dataloader = dict(
num_workers=4,
persistent_workers=False,
drop_last=False,
sampler=dict(type=DefaultSampler, shuffle=False),
dataset=dict(
type=val_dataset_type,
ann_file='tri_testlist.txt',
metainfo=dict(dataset_type='vimeo90k', task_name='vfi'),
data_root=data_root,
data_prefix=dict(img='sequences', gt='sequences'),
pipeline=train_pipeline,
depth=2,
load_frames_list=dict(img=['im1.png', 'im3.png'], gt=['im2.png'])))
]
# 5000 iters == 1 epoch
# optimizer
[docs]optim_wrapper = dict(
constructor='DefaultOptimWrapperConstructor',
type=OptimWrapper,
optimizer=dict(
type='Adam',
lr=5e-5,
betas=(0.9, 0.99),
weight_decay=1e-4,
),
)
# learning policy
[docs]param_scheduler = dict(
type=MultiStepLR,
by_epoch=False,
gamma=0.5,
milestones=[200000, 400000, 600000, 800000])
[docs]default_hooks = dict(
checkpoint=dict(
type=CheckpointHook,
interval=epoch_length,
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),
)