# Environment
GPU: 7                # list of gpu ids
SEED: 42            # random seed
DEBUG: False          # turns on debugging mode

# Experiment
MODE: test            # 1: train, 2: test, 3: eval
EPOCH: 300
RESUME: False
BATCH_SIZE: 8                 # input batch size for training
SAVE_DEST: /mnt/data/data_yxing/EXP/tvInpaint
EXP_NAME: single_test_example
SETUP_NAME: itde_boost

ALGO: ddnm

EDGE_THRESHOLD: 0.5           # edge detection threshold

GAN_LOSS: nsgan               # nsgan | lsgan | hinge
LR: 0.0001                    # lefarning rate
D2G_LR: 0.1                   # discriminator/generator learning rate ratio
BETA1: 0.0                    # adam optimizer beta1
BETA2: 0.9                    # adam optimizer beta2

FM_LOSS_WEIGHT: 10            # feature-matching loss weight
L1_LOSS_WEIGHT: 1             # l1 loss weight
STYLE_LOSS_WEIGHT: 250        # style loss weight
CONTENT_LOSS_WEIGHT: 0.1      # perceptual loss weight
INPAINT_ADV_LOSS_WEIGHT: 0.1  # adversarial loss weight

MODEL_EVAL_INTERVAL: 10

TRAIN_SAMPLE_INTERVAL:
  epoch: 10                    # the epoch interval for sampling during training
  batch: 50                   # the batch interval for sampling in a epoch
  index: 0                    # the index of which sample in a batch to sample
EVAL_SAMPLE_INTERVAL:
  batch: 1                   # the batch interval for sampling in a epoch
  index: 0                    # the index of which sample in a batch to sample
TEST_SAMPLE_INTERVAL:
  batch: 1
  index: 0

# Dataset
DATASET: tvStreet
INPUT_SIZE:      # target image size for using diffusion
  - 256
  - 256
CROP_SIZE: null      # if corp, then crop size must be provided
CENTRE_CROP: False
RANDOM_CROP: False
RANDOM_FLIP: False

GRID_MASK: # grid mask for refine dual misf output
  size:
    - 256 # width
    - 256 # height
  pix_interval: 30
  mask_width: 5

TRAIN_DATA_PATH: /home/yxing/projects/tvInpaint/data/img_pairs/train.txt
TRAIN_MASK_PATH: /home/yxing/projects/tvInpaint/data/mask_pairs/train.txt
VAL_DATA_PATH: /home/yxing/projects/tvInpaint/data/img_pairs/val.txt
VAL_MASK_PATH: /home/yxing/projects/tvInpaint/data/mask_pairs/val.txt
TEST_DATA_PATH: /home/yxing/projects/tvInpaint/data/img_pairs/test.txt
TEST_MASK_PATH: /home/yxing/projects/tvInpaint/data/mask_pairs/test_p40_60.txt

# Model

# KPN_MODEL_CHECKPOINT: 
DIFFUSION_MODEL_CHECKPOINT: 256x256_diffusion_uncond.pt
MISF_GEN_CHECKPOINT: /mnt/data/data_yxing/EXP/tvInpaint/train_dual_misf_for_cMap/train_both_heads_from_scratch_together_feature_share/checkpoint/29580_InpaintingModel_gen.pth
MISF_DIS_CHECKPOINT: ""

FILTER_TYPE: 64
# KERNEL_SIZE: 

DIFFUSION:
  diffusion_steps: 1000
  image_size: 256
  class_cond: False
  learn_sigma: True
  noise_schedule: linear
  timestep_respacing: '250'
  use_kl: False
  predict_xstart: False
  rescale_timesteps: False
  rescale_learned_sigmas: False
  use_fp16: True
  start_time_steps: 250
  use_checkpoint: False
  use_scale_shift_norm: True
  resblock_updown: True
  use_new_attention_order: False
  num_channels: 256
  num_res_blocks: 2
  channel_mult: ""
  num_heads: 4
  num_head_channels: 64
  num_heads_upsample: -1
  attention_resolutions:  32,16,8
  dropout: 0.0
  use_scale: True
  N: 50   # used for direcly replace x_N with x_misf

DDNM:
  travel_length: 1
  travel_repeat: 1

REPAINT:
  # T_sampling: 50 # this should be the same as start_time_steps in DIFFUSION
  travel_length: 10
  travel_repeat: 10

SINGLE:
  img_t0: /home/yxing/projects/tvInpaint/data/example/itdeboost_1_00.png
  mask_t0: /home/yxing/projects/tvInpaint/data/example/itdeboost_1_05637.png
  img_t1: /home/yxing/projects/tvInpaint/data/example/itdeboost_2_00.png
  mask_t1: /home/yxing/projects/tvInpaint/data/example/itdeboost_2_05648.png
