# general settings
name: Uformer_flare7kpp_baseline_option_PIP
model_type: SRModel
scale: 1
num_gpu: auto
manual_seed: 0
find_unused_parameters: True

# dataset and data loader settings
datasets:
  train:
    name: Flare7Kpp
    type: Flare7kpp_Pair_Loader
    image_path: dataset/Flickr24K
    scattering_dict:
      Flare7k_scattering: dataset/Flare7Kpp/Flare7K/Scattering_Flare/Compound_Flare
      Real_scattering1: dataset/Flare7Kpp/Flare-R/Compound_Flare
    reflective_dict: # you can also comment this part to get more robust result
      Flare7k_reflective: dataset/Flare7Kpp/Flare7K/Reflective_Flare 
      Real_reflective1: ~
    light_dict:
      Flare7k_light: dataset/Flare7Kpp/Flare7K/Scattering_Flare/Light_Source
      Real_light1: dataset/Flare7Kpp/Flare-R/Light_Source
    data_ratio: [0.5, 0.5] # the ratio should be like [0.6, 0.4], [0.7, 0.3]
    transform_base:
      img_size: 512
    transform_flare:
      scale_min: 0.7
      scale_max: 1.2
      translate: 100
      shear: 20
    mask_type: ~
    output_ch: 3
    
    # data loader
    use_shuffle: true
    num_worker_per_gpu: 4
    batch_size_per_gpu: 2
    dataset_enlarge_ratio: 1
    prefetch_mode: ~

  val:
    name: flare_test
    type: FlarePairDataset
    dataroot_gt: dataset/Flare7Kpp/val/gt
    dataroot_lq: dataset/Flare7Kpp/val/input
    io_backend:
      type: disk

# network structures
network_g:
  type: UformerPIP
  img_size: 512
  img_ch: 3
  output_ch: 6
  multi_stage: 1
  dim: 16
  Training: True

# path
path:
  pretrain_network_g: ~
  strict_load_g: true
  resume_state: ~

# training settings
train:
  optim_g:
    type: Adam
    lr: !!float 1e-4
    weight_decay: 0
    betas: [ 0.9, 0.99 ]

  scheduler:
    type: CosineAnnealingLR
    T_max: 600000
    eta_min: !!float 1e-7

  total_iter: 600000
  warmup_iter: -1 # no warm up

  # losses
  pixel_opt:
    type: CharbonnierLossColor
    loss_weight: 1.0
    reduction: mean
  # perceptual loss (content and style losses)
  perceptual_opt:
    type: PerceptualLoss
    layer_weights:
      # before relu
      'conv1_2': 0.1
      'conv2_2': 0.1
      'conv3_4': 1
      'conv4_4': 1
      'conv5_4': 1
    vgg_type: vgg19
    use_input_norm: true
    perceptual_weight: !!float 1.0
    style_weight: 0
    range_norm: false
    criterion: l1


# validation settings
val:
  val_freq: !!float 5e3
  save_img: false

  metrics:
    psnr: # metric name, can be arbitrary
      type: calculate_psnr
      crop_border: 0
      test_y_channel: false
    ssim:
      type: calculate_ssim
      crop_border: 0
      test_y_channel: false

# logging settings
logger:
  print_freq: 200
  save_checkpoint_freq: !!float 5e3
  use_tb_logger: true
  wandb:
    project: ~
    resume_id: ~

# dist training settings
dist_params:
  backend: nccl
  port: 29500