#!/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 ./main/Ask_is.py"

# -------------------------------------------------
for dataset in "${!data_paths[@]}"; do
  data_path="${data_paths[$dataset]}"
  split="${data_splits[$dataset]}"
  SAVE_BASE="./result/UnSAF/${dataset}/3000"

  for model_path in "${model_paths[@]}"; do
    for question_type in answerable unanswerable; do
      echo "==============================================================="
      echo "Dataset: $dataset"
      echo "Model  : ${model_path}"
      echo "QType  : $question_type"

      if [[ "$model_path" == *"llava"* ]]; then
        ASK_CONV_MODE="conv_llama_v2_vqa"
        ANS_CONV_MODE="llava_llama_2"
      elif [[ "$model_path" == *"Qwen"* ]]; then
        ASK_CONV_MODE="chatml_direct_q"
        ANS_CONV_MODE="chatml_direct"
      else
        ASK_CONV_MODE="conv_llama_v2_vqa"
        ANS_CONV_MODE="llava_llama_2"
      fi

      $base_command \
        --model_path "$model_path" \
        --device "cuda:0" \
        --data_path "$data_path" \
        --split "$split" \
        --temperature 1.0 \
        --num_test_samples 3000 \
        --ask_conv_mode "$ASK_CONV_MODE" \
        --ans_conv_mode "$ANS_CONV_MODE" \
        --problem_type "$question_type" \
        --save_base "$SAVE_BASE"\
        --dataset_name "$dataset"
    done
  done
done

echo "All datasets & models completed!"
