-
Notifications
You must be signed in to change notification settings - Fork 2
/
options.py
63 lines (57 loc) · 4.42 KB
/
options.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import os
import torch
class Options():
"""docstring for Options"""
def __init__(self):
pass
def init(self, parser):
# global settings
parser.add_argument('--batch_size', type=int, default=32, help='batch size')
parser.add_argument('--nepoch', type=int, default=250, help='training epochs')
parser.add_argument('--train_workers', type=int, default=4, help='train_dataloader workers')
parser.add_argument('--eval_workers', type=int, default=4, help='eval_dataloader workers')
parser.add_argument('--dataset', type=str, default ='SIDD')
parser.add_argument('--pretrain_weights',type=str, default='./log/Restormer_B/models/model_best.pth', help='path of pretrained_weights')
parser.add_argument('--optimizer', type=str, default ='adamw', help='optimizer for training')
parser.add_argument('--lr_initial', type=float, default=0.0002, help='initial learning rate')
parser.add_argument('--step_lr', type=int, default=50, help='weight decay')
parser.add_argument('--weight_decay', type=float, default=0.02, help='weight decay')
parser.add_argument('--gpu', type=str, default='6,7', help='GPUs')
parser.add_argument('--arch', type=str, default ='Restormer_B', help='archtechture')
parser.add_argument('--mode', type=str, default ='denoising', help='image restoration mode')
parser.add_argument('--dd_in', type=int, default=3, help='dd_in')
# args for saving
parser.add_argument('--save_dir', type=str, default ='./logs/', help='save dir')
parser.add_argument('--save_images', action='store_true',default=False)
parser.add_argument('--env', type=str, default ='_', help='env')
parser.add_argument('--checkpoint', type=int, default=50, help='checkpoint')
# args for Restormer
parser.add_argument('--norm_layer', type=str, default ='nn.LayerNorm', help='normalize layer in transformer')
parser.add_argument('--embed_dim', type=int, default=32, help='dim of emdeding features')
parser.add_argument('--win_size', type=int, default=8, help='window size of self-attention')
parser.add_argument('--token_projection', type=str,default='linear', help='linear/conv token projection')
parser.add_argument('--token_mlp', type=str,default='leff', help='ffn/leff token mlp')
parser.add_argument('--att_se', action='store_true', default=False, help='se after sa')
parser.add_argument('--modulator', action='store_true', default=False, help='multi-scale modulator')
# args for vit
parser.add_argument('--vit_dim', type=int, default=256, help='vit hidden_dim')
parser.add_argument('--vit_depth', type=int, default=12, help='vit depth')
parser.add_argument('--vit_nheads', type=int, default=8, help='vit hidden_dim')
parser.add_argument('--vit_mlp_dim', type=int, default=512, help='vit mlp_dim')
parser.add_argument('--vit_patch_size', type=int, default=16, help='vit patch_size')
parser.add_argument('--global_skip', action='store_true', default=False, help='global skip connection')
parser.add_argument('--local_skip', action='store_true', default=False, help='local skip connection')
parser.add_argument('--vit_share', action='store_true', default=False, help='share vit module')
# args for training
parser.add_argument('--train_ps', type=int, default=128, help='patch size of training sample')
parser.add_argument('--val_ps', type=int, default=128, help='patch size of validation sample')
parser.add_argument('--resume', action='store_true',default=False)
parser.add_argument('--train_dir', type=str, default ='./datasets/SIDD/train', help='dir of train data')
parser.add_argument('--val_dir', type=str, default ='./datasets/SIDD/val', help='dir of train data')
parser.add_argument('--warmup', action='store_true', default=False, help='warmup')
parser.add_argument('--warmup_epochs', type=int,default=3, help='epochs for warmup')
# ddp
parser.add_argument("--local_rank", type=int,default=-1,help='DDP parameter, do not modify')#不需要赋值,启动命令 torch.distributed.launch会自动赋值
parser.add_argument("--distribute",action='store_true',help='whether using multi gpu train')
parser.add_argument("--distribute_mode",type=str,default='DDP',help="using which mode to ")
return parser