# 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: 250613_pixel_opt

# data
data:
  dataset_name: ImageNet
  image_dir: data/images/imagenet-1k-sampled/source
  #image_names:         # lis of image names to use
  #  - "00000"
  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
  tol: 0.0001  # tolerance for the correlation distance

# batch size
batch_size: 64

# generator
generator:
  name: nogenerator

# loss function
critic:
  name: mse

# optimizer
optimizer:
  name: adamw
  lr: 0.01
  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