#!/bin/bash
declare -A data_paths=(
  # ["VQAv2"]="./datasets/vqav2/data" # split validation
  # ["OKVQA"]="./datasets/ok-vqa/data" # split val 
  ["VizWiz"]="./datasets/vizwiz-vqa/data" # split val
  # ["TextVQA"]="./datasets/textvqa/data" # split train
  # ["MMBench"]="./datasets/MMBench/en/dev-00000-of-00001.parquet" # split en_dev
)
declare -A data_splits=(
  ["VQAv2"]="validation"
  ["OKVQA"]="val"
  ["VizWiz"]="val"
  ["TextVQA"]="train"
  ["MMBench"]="en_dev"
)

model_paths=()

base_command="python -u ./main/NLL/VQAv2.py"

# -------------------------main forloop -------------------------- #
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"* ]]; 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 \
      --num_test_samples 4000 \
      --device "cuda:0" \
      --dataset_name "$dataset" \
      --split "$split" \
      --conv_mode "$conv_mode"
  done
done
echo "✅ All evaluations completed!"