# Config file for AttnFPN-def-DETR

# General training
experiment_name: fpn_msa_dqm_amos
device: cuda:0
val_interval: 1
debug_mode: False  # Doesn't save checkpoints
seed: 10

epochs: 2000
lr: 2e-4
lr_backbone: 2e-5
lr_linear_proj_mult: 0.1
weight_decay: 1e-4
clip_max_norm: 10

# Scheduler
lr_drop: 1250

# Data
dataset: amos_256_256_128_CT
overfit: False # Use same set consisting of one image for train and val
bbox_padding: 1

# Dataloader
batch_size: 2
shuffle: True
num_workers: 10

# Hungarian matching
set_cost_class: 2
set_cost_bbox: 5
set_cost_giou: 2
dense_q_matching: True # DQM enabled or not
dense_q_matching_lambda: 0.2

# Losses
focal_loss: False
loss_coefs:
  cls: 2      # Detection
  bbox: 5
  giou: 2
  segce: 2    # Segmentation proxy
  segdice: 2

# Model specific params
backbone:
  name: fpn
  layers: [3, 4, 6, 3] # it is used in resnet backbone
  # Standard params
  in_channels: 1  #  Input channels 
  start_channels: 32  # Channels after first encoder block
  fpn_channels: 384 # Final output channels
  bias: False
  norm_type: instance
  data_size: [256, 256, 128] 
  out_fmaps: [P5, P4, P3]  # P0, P1, P2, P3, P4, P5
  kernel_size: 3
  use_seg_proxy_loss: False  # never use it with msa
  fg_bg: False

neck:
  name: def_detr
  use_encoder: False # set false when msa is enabled
  msa: 
    # standard params of msa
    enabled: True
    bias: False
    patch_size: 2
    mlp_ratio: 2
    num_heads: 64
    depths: 2
    drop_path_rate: 0.3
    attn_drop_rate: 0
    drop_rate: 0.0
    qkv_bias: True
    cuda: 0
    # Segmentation proxy loss
    use_msa_seg_loss: True
    num_organs: 15 # should be consistent with the dataset
    
  
  input_level: P3
  num_feature_levels: 3

  pos_encoding: sine
  hidden_dim: 384
  dropout: 0.1
  nheads: 6
  dim_feedforward: 1024
  enc_layers: 3
  dec_layers: 3
  enc_n_points: 4
  dec_n_points: 4
  num_queries: 150
  aux_loss: True
  use_cuda: False
  two_stage: False
  box_refine: False


# Augmentation
augmentation:
  use_augmentation: True
  patch_size: [256, 256, 128]

  p_gaussian_noise: 0
  p_gaussian_smooth: 0
  p_intensity_scale: 0.5
  p_intensity_shift: 0.5
  p_adjust_contrast: 0
  p_rotate: 0.5
  p_zoom: 0.5
  p_shear: 0
  p_translate: 0.5
  p_flip: 0

  gaussian_noise_mean: 0.0
  gaussian_noise_std: 0.1
  gaussian_smooth_sigma: [0.5, 1.0]

  intensity_scale_factors: 0.1
  intensity_shift_offsets: 0.1

  adjust_contrast_gamma: [0.7, 1.5]

  rotation: [-5, 5]
  min_zoom: 0.9
  max_zoom: 1.1
  translate_precentage: 10
  shear_range: [0.1, 0.1, 0.1]
  flip_axis: [0, 1, 2]
