#!/bin/bash
device='5'
model='llava_med_v1.5'
# categories=("privacy" "bias" "toxicity" "hallucination" "legality")

validate_datasets='xray' # ['slake', 'rad', 'mimic_cxr', 'xray']
hallu_type='visual_misinterpretation' # visual_misinterpretation  knowledge_deficiency context_misalignment
answer_type='close'
probe_dataset='Mimic_Knowledge' # SLAKE  GEMeX
pos='I+Q+RD'
neg='I+Q_onlyr'
subfix='_len'

num_heads_list=(16 24)
alpha_list=(3 5 7)

for num_head in "${num_heads_list[@]}"; do
  # 内层循环
    for alpha in "${alpha_list[@]}"; do
        echo $num_head $alpha
        python code/inference_iti.py --model $model \
                        --validate_datasets $validate_datasets \
                        --probe_dataset $probe_dataset \
                        --pos $pos \
                        --neg $neg \
                        --hallu_type $hallu_type \
                        --answer_type $answer_type \
                        --device $device \
                        --num_heads $num_head \
                        --alpha $alpha \
                        --subfix $subfix \
                        --use_center_of_mass
                        
        new_subfix="_${num_head}_${alpha}_${probe_dataset}_${neg};${pos}${subfix}"
        
        if echo "$hallu_type" | grep -q "visual_misinterpretation"; then
            if echo "$answer_type" | grep -q "close"; then
              python code/evaluation/close_ended_evaluation/eval_type1_batch.py --model $model \
                              --datasets $validate_datasets \
                              --hallu_type $hallu_type \
                              --subfix $new_subfix
            else
              source ~/anaconda3/etc/profile.d/conda.sh
              conda activate eval_report
              python code/evaluation/report_eval/run_eval.py --model $model \
                              --datasets $validate_datasets \
                              --hallu_type $hallu_type \
                              --subfix $new_subfix
              conda activate llava_med
              python code/evaluation/report_eval/run_all_metrics.py --model $model \
                              --datasets $validate_datasets \
                              --hallu_type $hallu_type \
                              --subfix $new_subfix
            fi
        else
            if echo "$answer_type" | grep -q "close"; then
              python code/evaluation/close_ended_evaluation/eval_type23_close.py --model $model \
                              --datasets $validate_datasets \
                              --hallu_type $hallu_type \
                              --subfix $new_subfix
            else
              # source ~/anaconda3/etc/profile.d/conda.sh
              # conda activate eval_report
              # python code/evaluation/report_eval/run_eval.py --model $model \
              #                 --datasets $validate_datasets \
              #                 --hallu_type $hallu_type \
              #                 --subfix $new_subfix
              # conda activate llava_med
              python code/evaluation/report_eval/run_all_metrics.py --model $model \
                              --datasets $validate_datasets \
                              --hallu_type $hallu_type \
                              --subfix $new_subfix
            fi
        fi
    done
done