# general settings
# name: debug_DBCNN_LIVEC
name: 001_DBCNN_MPD
model_type: GeneralIQAModel
num_gpu: 1  # set num_gpu: 0 for cpu mode
manual_seed: 123
save_final_results_path: './experiments/DBCNN_LIVEChallenge_10splits_results.txt'

# dataset and data loader settings
datasets:
  train:
    name: 001_CLIPIQA_MPD
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR_train.csv
    mos_range: [0, 5]
    lower_better: false 
    mos_normalize: true

    augment:
      hflip: true
      random_crop: 128
    img_range: 1

    # data loader
    use_shuffle: true
    num_worker_per_gpu: 4
    batch_size_per_gpu: 256
    dataset_enlarge_ratio: 1
    prefetch_mode: ~
    phase: train

  # val_0:
  #   name: All
  #   type: GeneralNRDataset
  #   dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
  #   meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_All.csv
  #   img_range: 1
  #   phase: val
  
  val_1:
    name: score1
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_score1.csv
    img_range: 1
    phase: val
  
  val_2:
    name: score2
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_score2.csv
    img_range: 1
    phase: val
  
  val_3:
    name: score3
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_score3.csv
    img_range: 1
    phase: val
  
  val_4:
    name: perspective_F
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_perspective_F.csv
    img_range: 1
    phase: val
  
  val_5:
    name: perspective_T
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_perspective_T.csv
    img_range: 1
    phase: val
  
  val_6:
    name: reality_R
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_reality_R.csv
    img_range: 1
    phase: val
  
  val_7:
    name: reality_S
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_reality_S.csv
    img_range: 1
    phase: val
  
  # val_8:
  #   name: Object_Daily
  #   type: GeneralNRDataset
  #   dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
  #   meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_Object_Daily.csv
  #   img_range: 1
  #   phase: val
  
  # val_9:
  #   name: Object_Industrial
  #   type: GeneralNRDataset
  #   dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
  #   meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_Object_Industrial.csv
  #   img_range: 1
  #   phase: val
  
  val_10:
    name: dis-level_S4
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_dis-level_S4.csv
    img_range: 1
    phase: val
  
  val_11:
    name: dis-level_S5
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_dis-level_S5.csv
    img_range: 1
    phase: val
  
  val_12:
    name: dis-level_S6
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_dis-level_S6.csv
    img_range: 1
    phase: val
  
  val_13:
    name: dis-level_S7
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_dis-level_S7.csv
    img_range: 1
    phase: val
  
  val_14:
    name: dis-level_S8
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_dis-level_S8.csv
    img_range: 1
    phase: val

  # val_15:
  #   name: cross-vlm
  #   type: GeneralNRDataset
  #   dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
  #   meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_vlm.csv
  #   img_range: 1
  #   phase: val

  # val_16:
  #   name: cross-tid
  #   type: GeneralNRDataset
  #   dataroot_target: /tos-bjml-researcheval/dataset/tid2013/distorted_images
  #   meta_info_file: /tos-bjml-researcheval/dataset/tid2013/NR_mos_with_names_tiny_0-5.csv
  #   img_range: 1
  #   phase: val


  # val_17:
  #   name: cross-live
  #   type: GeneralNRDataset
  #   dataroot_target: /tos-bjml-researcheval/dataset/live
  #   meta_info_file: /tos-bjml-researcheval/dataset/live/NR_filename_mos_half_0-5.csv
  #   img_range: 1
  #   phase: val

  val_18:
    name: bottom_50
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_bottom_50.csv
    img_range: 1
    phase: val

  val_19:
    name: middle_50
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_middle_50.csv
    img_range: 1
    phase: val
  
  val_20:
    name: top_50
    type: GeneralNRDataset
    dataroot_target: /fs-computility/ResearchEval/shared/MY_DATA_1000_all
    meta_info_file: /fs-computility/ResearchEval/project/vlm_meta_info/vlm_meta_info_sampled/NR/NR_top_50.csv
    img_range: 1
    phase: val

# network structures
network:
  type: DBCNN
  pretrained_scnn_path: /DATA/wfr/IQA-PyTorch/DBCNN_scnn-7ea73d75.pth

# path
path:
  pretrain_network_g: ~
  strict_load_g: true
  resume_state: ~
  experiments_root: /fs-computility/ResearchEval/models/IQA-PyTorch/experiments/001_frAHIQ
  models: /fs-computility/ResearchEval/models/IQA-PyTorch/experiments/001_frAHIQ/models
  training_states: /fs-computility/ResearchEval/models/IQA-PyTorch/experiments/001_frAHIQ/training_states
  log: /fs-computility/ResearchEval/models/IQA-PyTorch/experiments/001_frAHIQ
  visualization: /fs-computility/ResearchEval/models/IQA-PyTorch/experiments/001_frAHIQ/visualization

# training settings
train:
  optim:
    type: SGD
    lr: 0.001
    momentum: 0.9
    weight_decay: 0.0005

  optim_finetune:
    type: Adam
    lr: 1e-05
    weight_decay: 0.0005

  scheduler:
    type: MultiStepLR
    milestones: [1000]
    gamma: 1

  scheduler_finetune:
    type: MultiStepLR
    milestones: [1000]
    gamma: 1

  total_iter: 50000
  finetune_start_iter: 10
  warmup_iter: -1  # no warm up

  # losses
  mos_loss_opt:
    type: MSELoss
    loss_weight: !!float 1.0
    reduction: mean

# validation settings
val:
  val_freq: 200.0
  save_img: false
  pbar: true

  key_metric: srcc # if this metric improve, update all metrics. If not specified, each best metric results will be updated separately
  metrics:
    srcc:
      type: calculate_srcc

    plcc:
      type: calculate_plcc

    krcc:
      type: calculate_krcc

# logging settings
logger:
  print_freq: 10
  save_checkpoint_freq: 5000000000.0
  save_latest_freq: 500.0
  use_tb_logger: true
  wandb:
    project: ~
    resume_id: ~

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

find_unused_parameters: True
dist: False
rank: 0
world_size: 1
auto_resume: False
is_train: True
root_path: /fs-computility/ResearchEval/models/IQA-PyTorch
