# Configuration for ensemble_3models.py

defaults:
  - _self_

data:
  batch_size: 10
  num_samples: 1000
  output: "./LAT"
  cle_data_path: "resources/images/bigscale"
  tgt_data_path: "resources/images/target_images"
  retrieval_path: "resources/retrieved_embeddings"

optim:
  alpha: 0.005
  epsilon: 16
  steps: 300
  optimizer: "adam"  # or "adam"
  momentum: 0.9     # for SGD
  momentum_decay: 0.9  # used for MI-FGSM
  align: pooler_weighted # can be [pooler, pooler_weighted, tm, cls_weighted] tm for trajectory matching
  tm_idx: [-2,-1] # the layer index to align with
  beta: 0.3 # for pooler_weighted
  use_retrieval: true # Explicitly enable retrieval
  multi_pass_num: 10

model:
  input_res: 224
  crop_scale_1: [0.5, 1.0] 
  crop_scale_2: [0.5, 1.0]
  crop_scale_3: [0.5, 1.0]
  changer_iters: [40, 260]
  ensemble: true
  device: "cuda:5"  # Using GPU 1
  target_crop: true
  # the backbone can select from
  # clip: clip_b16, clip_b32, clip_l14, clip_l336, clip_laion, clip_laion_multilingual
  # dinov2: dino_small, dino_base, dino_large
  # blip2: blip2_2.7b, blip2_6.7b, blip2_flan, blip2_coco
  # cnn: inception_v3, resnet50
  # blip1: blip1_base, blip1_large, blip1_vqa
  # backbone: ["clip_b16", "clip_b32", "clip_laion"]
  # vit: vit_b16, vit_b32, vit_h14
  backbone: ['clip_b16','clip_b32','clip_laion_b32','clip_laion_g14']
  # backbone: ['clip_b16', 'clip_b32']
  target_num: 3  # Number of target crops to align with each source image
  device_ids: [0,1,2,3,4] # parallel images

wandb:
  project: "local_adversarial_attack"
  entity: ??? # fill your wandb entity
  run_name_prefix: "test" # Add a prefix to wandb run names, e.g., "dev" or "exp1"

blackbox:
  model_name: ["gpt4o", "claude3.7t", "gemini2.5pro"]  # List of models to call in parallel can be gpt4o, claude, gemini
  batch_size: 1
  timeout: 30
  parallel_images: 2  # Number of images to process in parallel

white_transfer:
  target_models: [ "clip_laion_g14", "clip_l14", "dino_small", "dino_base", "dino_large", "blip2_2.7b", "clip_b16", "clip_laion_b16", "clip_b32", "clip_laion_b32",]
  batch_size: 20
  timeout: 30
  parallel_images: 2  # Number of images to process in parallel


attack: 'pgd_multi_pass' # [fgsm, mifgsm, pgd, pgd_multi_pass]