36 lines
1.0 KiB
Python
36 lines
1.0 KiB
Python
_base_ = [
|
|
'../_base_/models/byol.py',
|
|
'../_base_/datasets/imagenet_byol.py',
|
|
'../_base_/schedules/lars_coslr-200e_in1k.py',
|
|
'../_base_/default_runtime.py',
|
|
]
|
|
|
|
# dataset summary
|
|
data = dict(samples_per_gpu=256, workers_per_gpu=8)
|
|
|
|
# additional hooks
|
|
# interval for accumulate gradient, total 16*256*1(interval)=4096
|
|
update_interval = 1
|
|
custom_hooks = [
|
|
dict(type='BYOLHook', end_momentum=1., update_interval=update_interval)
|
|
]
|
|
|
|
# optimizer
|
|
optimizer = dict(
|
|
type='LARS',
|
|
lr=4.8,
|
|
momentum=0.9,
|
|
weight_decay=1e-6,
|
|
paramwise_options={
|
|
'(bn|gn)(\\d+)?.(weight|bias)':
|
|
dict(weight_decay=0., lars_exclude=True),
|
|
'bias': dict(weight_decay=0., lars_exclude=True)
|
|
})
|
|
optimizer_config = dict(update_interval=update_interval)
|
|
|
|
# runtime settings
|
|
# the max_keep_ckpts controls the max number of ckpt file in your work_dirs
|
|
# if it is 3, when CheckpointHook (in mmcv) saves the 4th ckpt
|
|
# it will remove the oldest one to keep the number of total ckpts as 3
|
|
checkpoint_config = dict(interval=10, max_keep_ckpts=3)
|