version: 2

train_file:  ['/notebooks/data/flickr30k/flickr30k-train-pairs.json']
val_file: '/notebooks/data/flickr30k/flickr30-test-pairs.json' 
test_file: '/notebooks/data/flickr30k/flickr30-test-pairs.json'
image_root: '/notebooks/data/flickr30k/flickr30k_images/flickr30k_images/'  
save_sims: './storage/10/albef-sims'

image_res: 256 #384
embed_dim: 768
temp: 0.07
batch_size_train: 32
batch_size_test: 512
k_test: 128

alpha: 0.4

optimizer: {opt: adamW, lr: 1e-5, weight_decay: 0.02} 
schedular: {sched: cosine, lr: 1e-5, epochs: 10, min_lr: 1e-6, decay_rate: 1, warmup_lr: 1e-5, warmup_epochs: 1, cooldown_epochs: 0}

text_encoder: openai/clip-vit-large-patch14
vision_encoder: facebook/dinov2-large
adapter_append: false

model_config:  
  import_path: models.clip_adjustable_custom_pacl.CLIP

classification_config:
  import_path: classification.evaluation_pacl
  import_path_vdt: classification.evaluation_pacl_vdt



# This doesn't matter for evaluation, but we have to
# include it anyway because my code is spaghetti rn.
pretrained_text: true
pretrained_vision: true
freeze_text_encoder: false
freeze_vision_encoder: false
unlock_layernorm: false
limit_num_samples: false
add_adapter: false
freeze_proj: false
unlock_dense: false
unlock_attn: false
unlock_random: false
bitfit: false

# pooling for vision
vis_pooling: mean
local_vision_projection: 'patch'


always_freeze:
  visual_encoder: []
  text_encoder: []
fp16: true

# This should match how the model was trained, or results
# will not make sense.

conventional_adapter:
  insert: false
  reduction_factor: 4

fg_thresh: 0.3