import os, sys

sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
from utils.agent import CommonAgents
from utils.eval import EVAL

sys.path.append(os.path.dirname(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))))
from gpt_api.unigpt import GPT


# miniforge3/condabin/conda run -n chartqa --live-stream python project/chartqa/src/evaluation/chartqa/src/eval_closed/eval_qwen.py
if __name__ == "__main__":
    base_url = "https://dashscope.aliyuncs.com/compatible-mode/v1"
    api_key = ""

    ### qwen-vl-max
    model_name = "qwen-vl-max"
    agent = CommonAgents(
        engine=model_name,
        if_reasoner=False,
        stream=False,
        base_url=base_url,
        api_key=api_key,
        if_azure=False,
        if_anthropic=False,
        if_doubao=False,
    )
    eval = EVAL(agent, os.path.join("project/chartqa/result/cot", model_name))
    eval.run_all_prediction(max_workers=10)

    # ### qvq-max
    # model_name = "qvq-max"
    # agent = CommonAgents(
    #     engine=model_name,
    #     if_reasoner=False,
    #     stream=False,
    #     base_url=base_url,
    #     api_key=api_key,
    #     if_azure=False,
    #     if_anthropic=False,
    #     if_doubao=False,
    # )
    # eval = EVAL(agent, os.path.join("project/chartqa/result", model_name))
    # eval.run_all_prediction(max_workers=10)

    # ### Qwen/Qwen2.5-VL-32B-Instruct
    # base_url = ""
    # api_key = ""
    # model_name = "Qwen/Qwen2.5-VL-32B-Instruct"
    # agent = CommonAgents(
    #     engine=model_name,
    #     if_reasoner=False,
    #     stream=False,
    #     base_url=base_url,
    #     api_key=api_key,
    #     if_azure=False,
    #     if_anthropic=False,
    #     if_doubao=False,
    # )
    # eval = EVAL(agent, os.path.join("project/chartqa/result", model_name))
    # eval.run_all_prediction(max_workers=10)
