# Readout vision - feature inversion on noised features

# model config
model:  
    # model family name
    name: vgg19-lab
    # path to the pretrained weights or huggingface model name
    pretrained: data/models/vgg19-lab/VGG_ILSVRC_19_layers.pt  # path to the pretrained weights
    # model alias (optional)
    # model_alias:

# experiment name: used for logging and saving results
# results will be saved under output/readout_vision/results/{model_name}/{dataset_name}/{exp_name}/
exp_name: 250904_DIP_more_seeds

# data
data:
  dataset_name: ImageNet
  image_dir: data/images/imagenet-1k-sampled/source
  image_names:         # lis of image names to use
    - "00000"
    - "00001"
    - "00002"
    - "00003"
  #image_names_path: data/images/imagenet-1k-sampled/derivatives/image_names_64.yaml  # file with image names to use
  image_ext: ".JPEG"  # image extension with dot, e.g. ".JPEG" or ".jpg"

# noise
noise:
  target_corr_dists:  # target correlation distance for the noise
    - 0.0
    - 0.1
    - 0.2
    - 0.3
    - 0.4
    - 0.5
    - 0.6
    - 0.7
    - 0.8
    - 0.9
    - 0.99
  noise_seeds:   # random seeds for the noise generation
    - 0
    - 1
    - 2
    - 3
    - 4
    - 5
    - 6
    - 7
    - 8
    - 9
    - 10
    - 11
    - 12
    - 13
    - 14
    - 15
    - 16
    - 17
    - 18
    - 19
    - 20
    - 21
    - 22
    - 23
    - 24
    - 25
    - 26
    - 27
    - 28
    - 29
    - 30
    - 31
    - 32
    - 33
    - 34
    - 35
    - 36
    - 37
    - 38
    - 39
    - 40
    - 41
    - 42
    - 43
    - 44
    - 45
    - 46
    - 47
    - 48
    - 49
    - 50
    - 51
    - 52
    - 53
    - 54
    - 55
    - 56
    - 57
    - 58
    - 59
    - 60
    - 61
    - 62
    - 63
  tol: 0.0001  # tolerance for the correlation distance

# batch size
batch_size: 64

# generator
generator:
  name: deepimageprior

# loss function
critic:
  name: mse

# optimizer
optimizer:
  name: adamw
  lr: 0.0001
  scheduler:
    name: LinearLR
    start_factor: 1.0
    end_factor: 0.0

# parameters for the feature inversion pipeline
pipeline:
  num_iterations: 10000
  eval_interval: 100
  wandb_log_interval: 10

# list of layers to use (human readable names)
# note that reconstruction is performed for each layer separately
layers:
  - conv1_1
  #- conv1_2
  #- conv2_1
  #- conv2_2
  - conv3_1
  #- conv3_2
  #- conv3_3
  #- conv3_4
  - conv4_1
  #- conv4_2
  #- conv4_3
  #- conv4_4
  - conv5_1
  #- conv5_2
  #- conv5_3
  #- conv5_4

# human readable layer name to actual layer name
layer_mapping:  
  'conv1_1': 'features[0]'
  'conv1_2': 'features[2]'
  'conv2_1': 'features[5]'
  'conv2_2': 'features[7]'
  'conv3_1': 'features[10]'
  'conv3_2': 'features[12]'
  'conv3_3': 'features[14]'
  'conv3_4': 'features[16]'
  'conv4_1': 'features[19]'
  'conv4_2': 'features[21]'
  'conv4_3': 'features[23]'
  'conv4_4': 'features[25]'
  'conv5_1': 'features[28]'
  'conv5_2': 'features[30]'
  'conv5_3': 'features[32]'
  'conv5_4': 'features[34]'
  'fc6': 'classifier[0]'
  'relu6': 'classifier[1]'
  'fc7': 'classifier[3]'
  'relu7': 'classifier[4]'
  'fc8': 'classifier[6]'


# Optional parameters ----------------
# wandb settings (optional)
wandb: True
