import argparse
import os
from tqdm import tqdm
import pandas as pd
from evaluator.VizWiz import eval_model
import pandas as pd
from Models.LLaVA import LLaVA_7B, LLaVA_13B
from Models.Qwen2VL import Qwen2VL
from Models.InternVL3 import InternVL3
from Models.InternVL2 import InternVL2
from Models.Qwen_VL_Chat import QwenVLChat
from Models.Qwen import Qwen
from Models.Qwen2p5_VL_Instruct import Qwen2p5_VL_Instruct
from Models.BLIP2 import BLIP2
from Models.InstructBLIP import InstructBLIP
from utils.ECE import *
from utils.utils import *
import json
from PIL import Image
import glob
from utils.conversation import conv_templates, DEFAULT_IMAGE_PATCH_TOKEN, DEFAULT_IM_START_TOKEN, DEFAULT_IM_END_TOKEN, DEFAULT_IMAGE_TOKEN

from evaluator.CotAnswer import cot_answer, evaluate_uncertainty
from utils.prompt import *
from utils.GPTprompt import *
from Ask import get_model_class, generate_questions

def main(args):

    ModelClass = get_model_class(args.model_path)
    model = ModelClass(args)


    generate_questions(model, args)
    cot_answer(model, args)

    if args.prompt_version is not None:
        evaluate_uncertainty(model, args.prompt_version, args)
        
    else:
        prompt_generators = {
            "answerable": generate_answerable_prompts,
            "unanswerable": generate_unanswerable_prompts
        }
        prompt_versions = prompt_generators[args.problem_type]()

        sorted_versions = sorted(
            prompt_versions.keys(),
            key=lambda x: int(x[1:])  
        )

        for version in sorted_versions:
            evaluate_uncertainty(model, version, args)


if __name__ == "__main__":
    parser = argparse.ArgumentParser(description="Distillation for COT Answer Generation")
    parser.add_argument('--model_path', type=str,help="Path to the pre-trained or distilled model file. Specify the location of the model.")
    parser.add_argument("--model-base", type=str, default=None)
    parser.add_argument('--device', type=str, default="cuda:0")
    parser.add_argument('--data_path', type=str, help="Path to the dataset.")
    parser.add_argument('--temperature', type=float, default=1.0)
    parser.add_argument('--num_test_samples', type=int, default=1)
    parser.add_argument('--prompt_version', type=str, default=None)
    parser.add_argument("--ask_conv_mode", default="conv_llama_v2_vqa",help="The ask prompt of model")# (mistral_instruct, chatml_direct, llava_v1, mpt, llava_v0, llava_llama_2, conv_llama_v2_vqa)
    parser.add_argument("--ans_conv_mode", default="llava_llama_2",help="The answer prompt of model") # (mistral_instruct, chatml_direct, llava_v1, mpt, llava_v0, llava_llama_2, conv_llama_v2_vqa)
    parser.add_argument("--problem_type", default="answerable", help="The type of questions you want the MllM to generate.") # (answerable, unanswerable)
    parser.add_argument('--save_base', type=str, default="./result/cot", help="Directory path where the results will be saved.")
    args = parser.parse_args()
    main(args)
