import json
import os
from together import Together
from tqdm import tqdm

os.environ["TOGETHER_API_KEY"] = "YOUR_API_KEY"
client = Together(api_key=os.environ.get("TOGETHER_API_KEY")) # Initialize the Together client

# Define a function to run inference on the model
def run_inference(model, question, input):
    prompt = f"Given a Question and Options , please select the right answer. Your answer should be \nA\nB\nC\nD.\n\nQuestion: {question} \n\nInput: {input}\n\n Please directly give the answer without any explanation withe correct choice"
    # Run the model on the prompt
    response = client.chat.completions.create(
        model=model,
        messages=[
            {"role": "assistant", "content": "You are a expert assistant in physics who can solve all the question given to you correctly."},
            {"role": "user", "content": prompt}
        ]
    )
    # Extract the response from the model
    response = response.choices[0].message.content.strip()
    return response

# Load the JSON file containing the questions and input
with open('', 'r') as file:
    data = json.load(file)

save_results = []
# Iterate through each response in the JSON file
for idx, item in enumerate(tqdm(data, desc="Evaluating responses")):
    question = item['question']
    input = item['input']

    # Evaluate the model's response
    response = run_inference("", question, input)
    print(response)

    # Save the evaluation result
    item['response'] = response
    save_results.append(item)

    # Save the results every 10 responses
    if (idx+1) % 10 == 0:
        # Read existing results from the file, if it exists
        existing_results = []
        with open('', 'r') as file:
            existing_results = json.load(file)
        # Append the new results to the existing results
        for i in save_results:
            existing_results.append(i)
        # Save the results to the file
        with open('', 'w') as file:
            json.dump(existing_results, file, indent=4)
        save_results = []


