{
  "task": "srformer_x4_gan_saitgan" // root/task/images|models|options
  , "model": "gan"        // "gan"
  , "gpu_ids": [0,1,2,3]        // [0,1,2,3] for 4 GPUs
  , "noDT": false  

  , "scale": 4       // broadcast to "netG" if SISR
  , "n_channels": 3  // broadcast to "datasets", 1 for grayscale, 3 for color

  , "path": {
    "root": "superresolution"  // "denoising" | "superresolution"
    , "pretrained_netG": "/mnt/server5_hard1/seungjun/KAIR-master/superresolution/srformer_x4_gan/models/SRFormer_SRx4_DF2K.pth" // path of pretrained model
    , "pretrained_netD": null  // path of pretrained model
	, "pretrained_netE": null  // path of pretrained model
    , "pretrained_netDT": null  // path of pretrained model
	}

  , "datasets": {
    "train": {
      "name": "train_dataset"           // fixed
      , "dataset_type": "blindsr"       // "dncnn" | "dnpatch" | "fdncnn" | "ffdnet" | "sr" | "srmd" | "dpsr" | "plain" | "plainpatch"
      , "dataroot_H": "/mnt/server5_hard1/seungjun/KAIR-master/trainsets/trainH"// path of H training dataset
      , "dataroot_L": "/mnt/server5_hard1/seungjun/KAIR-master/trainsets/trainL_realdegrade/X4"              // path of L training dataset

      , "degradation_type": "bsrgan"    // "bsrgan" | "bsrgan_plus"
      , "H_size": 256                   // patch_size 256 | 288 | 320
      , "shuffle_prob": 0.1             // 
      , "lq_patchsize": 64
      , "use_sharp": true

      , "dataloader_shuffle": true
      , "dataloader_num_workers": 8     // 8 | 32 | 64
      , "dataloader_batch_size": 12      // batch size 1 | 16 | 32 | 48 | 64 | 128
    }
    , "test": {
      "name": "test_dataset"            // fixed
      , "dataset_type": "blindsr"

      , "degradation_type": "bsrgan"    // "bsrgan" | "bsrgan_plus"
      , "H_size": 256                   // patch_size 256 | 288 | 320
      , "shuffle_prob": 0.1             // 
      , "lq_patchsize": 64
      , "use_sharp": false

      , "dataroot_H": "/mnt/server5_hard1/seungjun/KAIR-master/testsets/testH"   // path of H testing dataset
      , "dataroot_L": "/mnt/server5_hard1/seungjun/KAIR-master/testsets/testL/X4"              // path of L testing dataset
    }
  }

  , "netG": {
    "net_type": "SRFormer"
    , "upscale": 4
    , "in_chans": 3
    , "img_size": 64
    , "window_size": 22
    , "img_range": 1.0
    , "depths": [6, 6, 6, 6, 6, 6]
    , "embed_dim": 180
    , "num_heads": [6, 6, 6, 6, 6, 6]
    , "mlp_ratio": 2
    , "upsampler": "pixelshuffle"        // "pixelshuffle" | "pixelshuffledirect" | "nearest+conv" | null
    , "resi_connection": "1conv"        // "1conv" | "3conv"

    , "init_type": "default"
  }

  , "netD": {
    "net_type": "discriminator_unet" // "discriminator_patchgan" | "discriminator_unet"
    , "in_nc": 3
    , "base_nc": 64
    , "n_layers": 3                  // only for "net_type":"discriminator_patchgan"
    , "norm_type": "spectral"        // only for "net_type":"discriminator_patchgan"  | 'batch', 'instance', 'spectral', 'batchspectral', 'instancespectral'

    , "init_type": "orthogonal"      // "orthogonal" | "normal" | "uniform" | "xavier_normal" | "xavier_uniform" | "kaiming_normal" | "kaiming_uniform"
    , "init_bn_type": "uniform"      // "uniform" | "constant"
    , "init_gain": 0.2
  }

  , "train": {
    "G_lossfn_type": "l1"    // "l1" | "l2" | "l2sum" | "l1c" | "ssim"
    , "G_lossfn_weight": 1

    , "F_lossfn_type": "l1"  // "l1" | "l2"
    , "F_lossfn_weight": 1
    , "F_feature_layer": [2,7,16,25,34]        // 25 | [2,7,16,25,34]
    , "F_weights": [0.1,0.1,1.0,1.0,1.0]       // 1.0 | [0.1,0.1,1.0,1.0,1.0]
    , "F_use_input_norm": true
    , "F_use_range_norm": false

    , "gan_type": "gan"     // "gan" | "ragan" | "lsgan" | "wgan" | "softplusgan"
    , "D_lossfn_weight": 0.1

    , "E_decay": 0.999        // Exponential Moving Average for netG: set 0 to disable; default setting 0.999

    , "D_init_iters": 0

    , "G_optimizer_type": "adam"
    , "G_optimizer_lr": 1e-4  // learning rate
    , "G_optimizer_wd": 0

    , "D_optimizer_type": "adam"
    , "D_optimizer_lr": 1e-4  // learning rate
    , "D_optimizer_wd": 0
      
    , "DT_optimizer_type": "adam"
    , "DT_optimizer_lr": 1e-4  // learning rate
    , "DT_optimizer_wd": 0

    , "G_scheduler_type": "MultiStepLR"
    , "G_scheduler_milestones": [400000, 500000, 550000, 575000, 600000]
    , "G_scheduler_gamma": 0.5
    , "G_optimizer_reuse": true

    , "D_scheduler_type": "MultiStepLR"
    , "D_scheduler_milestones": [400000, 500000, 550000, 575000, 600000]
    , "D_scheduler_gamma": 0.5
    , "D_optimizer_reuse": false

    , "G_param_strict": true
    , "D_param_strict": true
    , "E_param_strict": true

    , "checkpoint_test": 5000  // skip testing
    , "checkpoint_save": 5000
    , "checkpoint_print": 200
  }
}

