import asyncio
import yaml
import sys
import os
import re
import json
import random
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))

from tools.lvm_pool import async_gpt4o, async_claude_3_5_sonnet, async_gemini_1_5_pro
from tools.image_to_url import local_image_to_data_url

async_examiner_function = {
    "gpt-4o": async_gpt4o,
    "claude_3_5_sonnet": async_claude_3_5_sonnet,
    "gemini_1_5_pro": async_gemini_1_5_pro,
}

config_file_path = './config/config.yaml'
with open(config_file_path, 'r', encoding='utf-8') as file:
    config = yaml.safe_load(file)

align_question_template = config.get('tifa_question_prompt')
align_answer_template = config.get('tifa_answer_prompt')

async def generate_and_evaluate_image(image_path, prompt):
    description = prompt
    
    prompt = align_question_template.format(description=description)
    response_text = await async_gpt4o(prompt)

    questions_results = re.sub(r"```json(.*?)```", r"\1", response_text, flags=re.DOTALL).strip()
    questions_results = json.loads(questions_results)

    responses = []
    # image_url = local_image_to_data_url(image_path)

    tasks = [
        answer_single(question, align_answer_template, image_path)
        for question in questions_results
    ]

    responses = await asyncio.gather(*tasks)
    
    correct = sum(1 for r in responses if r['llm_answer'] == r['correct_answer'])
    total = len(responses)
    score = correct / total if total > 0 else 0

    results = {
        'image_path': image_path,
        'score': score,
        'responses': responses
    }

    return float(score), results

async def answer_single(item, align_answer_template, image_path):
    prompt = align_answer_template.format(
        question=item['question'],
        choices=item['choices']
    )
    # model_name = random.choice(list(async_examiner_function.keys()))
    # llm_answer = await async_examiner_function[model_name](prompt, image_url)
    llm_answer = await async_gpt4o(prompt, image_path)
    llm_answer = re.sub(r"```json(.*?)```", r"\1", llm_answer, flags=re.DOTALL).strip()
    llm_answer = json.loads(llm_answer)
    response = {
        "question":item['question'],
        "choices":item['choices'],
        "llm_answer":llm_answer['answer'],
        "correct_answer":item['answer'],
    }

    return response

# if __name__ == '__main__':
#     image_path = "./document/basic_understanding/extracted_images/easy/0f2ab8ed-38a2-41bf-928c-7e54fec8c898.png"
#     prompt = "A cat sitting on a table in a kitchen with various utensils hanging on the wall behind it."
#     results = asyncio.get_event_loop().run_until_complete(generate_and_evaluate_image(image_path, prompt))
#     # save the results to a file
#     with open('1.txt', 'w') as f:
#         json.dump(results, f, indent=4)
#     print(results)
