import json
import os
from together import Together
from tqdm import tqdm

os.environ["TOGETHER_API_KEY"] = "API_KEY" 
client = Together(api_key=os.environ.get("TOGETHER_API_KEY")) # Initialize the Together client

def run_inference(model, question, input):
    # Generating a prompt for the model
    prompt = f"Solve the following Question Step by Step \n\nQuestion: {question}\n\n Input: {input} \n\n finally respond with correctly input choice without fail."
    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)

# Initialize a list to save the results
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 a file
        with open('', 'w') as file:
            json.dump(existing_results, file, indent=4)
        save_results = []



