# Readout vision - feature inversion on noised features

# model config
model:  
    # model family name
    name: dinov2-tfm
    # path to the pretrained weights or huggingface model name
    pretrained: "facebook/dinov2-giant"
    # 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_DIP

# 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: 8

# 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: 1000
  wandb_log_interval: 100

# list of layers to use (human readable names)
# note that reconstruction is performed for each layer separately
layers:
  - layer_0
  - layer_10
  - layer_20
  - layer_30

# human readable layer name to actual layer name
layer_mapping:
  layer_0: encoder.layer.0
  layer_1: encoder.layer.1
  layer_2: encoder.layer.2
  layer_3: encoder.layer.3
  layer_4: encoder.layer.4
  layer_5: encoder.layer.5
  layer_6: encoder.layer.6
  layer_7: encoder.layer.7
  layer_8: encoder.layer.8
  layer_9: encoder.layer.9
  layer_10: encoder.layer.10
  layer_11: encoder.layer.11
  layer_12: encoder.layer.12
  layer_13: encoder.layer.13
  layer_14: encoder.layer.14
  layer_15: encoder.layer.15
  layer_16: encoder.layer.16
  layer_17: encoder.layer.17
  layer_18: encoder.layer.18
  layer_19: encoder.layer.19
  layer_20: encoder.layer.20
  layer_21: encoder.layer.21
  layer_22: encoder.layer.22
  layer_23: encoder.layer.23
  layer_24: encoder.layer.24
  layer_25: encoder.layer.25
  layer_26: encoder.layer.26
  layer_27: encoder.layer.27
  layer_28: encoder.layer.28
  layer_29: encoder.layer.29
  layer_30: encoder.layer.30
  layer_31: encoder.layer.31
  layer_32: encoder.layer.32
  layer_33: encoder.layer.33
  layer_34: encoder.layer.34
  layer_35: encoder.layer.35
  layer_36: encoder.layer.36
  layer_37: encoder.layer.37
  layer_38: encoder.layer.38
  layer_39: encoder.layer.39



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