#!/bin/bash
declare -A data_paths=(
  # ["VQAv2"]="./datasets/vqav2/data"
  # ["OKVQA"]="./datasets/ok-vqa/data"
  # ["VizWiz"]="./datasets/vizwiz-vqa/data"
  # ["TextVQA"]="./datasets/textvqa/data"
)
declare -A data_splits=(
  ["VQAv2"]="validation"
  ["OKVQA"]="val"
  ["VizWiz"]="val"
  ["TextVQA"]="train"
)

save_base="./result/ACC"

# =============== model path ===============
model_paths=(xxx)

base_command="python -u ./main/ACC.py"

# ================================
for dataset in "${!data_paths[@]}"; do
  data_path="${data_paths[$dataset]}"
  split="${data_splits[$dataset]}"

  for model_path in "${model_paths[@]}"; do
    echo -e "\n\033[32m>>> Evaluating: ${model_path} on ${dataset}\033[0m"

    if [[ "$model_path" == *"llava"* ]]; then
      conv_mode="llava_llama_2"
    elif [[ "$model_path" == *"Qwen"* || "$model_path" == *"qwen"* ]]; then
      conv_mode="chatml_direct"
    else
      conv_mode="llava_llama_2"
    fi

    $base_command \
      --model_path "$model_path" \
      --data_path  "$data_path" \
      --temperature 1.0 \
      --device "cuda:0" \
      --dataset_name "$dataset" \
      --split "$split" \
      --conv_mode "$conv_mode" \
      --save_base "$save_base"
  done
done

echo -e "\n✅ All evaluations completed!"
