import asyncio
import os
import pandas as pd
from src.ring.belief import Belief
from src.pd.pd import PD
from src.pd.role import Role

class PDExperiment:
    debug = True
    def __init__(self, models: list[str],
                 version: str,
                 anonymised: bool,
                 temperature: float,
                 iterations: int,
                 output_file: str):
        self.models = models
        self.version = version
        self.anonymised = anonymised
        self.temperature = temperature
        self.iterations = iterations
        self.output_file = output_file  # Path to the CSV output file

    def protect_reasoning(self, reasoning):
        if reasoning:
            return f'"{reasoning.replace("\"", "\"\"")}"'
        return reasoning

    async def run_experiment(self):
        file_exists = os.path.isfile(self.output_file)
        for model in self.models:
            if self.debug:
                print(f"Running experiment for model: {model}")
            for role in Role:
                print(f"Running with role: {role.name}")
                for iteration in range(1, self.iterations + 1):
                    print(f"Iteration: {iteration}")
                    game_agent = PD(
                        model=model,
                        version=self.version,
                        anonymized=self.anonymised,
                        temperature=self.temperature,
                        role=role.value
                    )
                    try:
                        agent_response = await game_agent.run()
                        action = agent_response['action']
                        rationality = agent_response['rationality']
                        reasoning = agent_response['reasoning']
                        reasoning = self.protect_reasoning(reasoning)
                    except Exception as e:
                        print(f"Error in iteration {iteration} for model {model} : {e}")
                        action, reasoning, rationality = None, None, None
                    df = pd.DataFrame([{
                        'Iteration': iteration,
                        'Model': model,
                        'Temperature': self.temperature,
                        'Version': self.version,
                        'Anonymized': self.anonymised,
                        'Role': role.name,
                        'Action': action,
                        'Rationality': rationality,
                        'reasoning': reasoning
                    }])
                    df.to_csv(self.output_file, mode='a', header=not file_exists, index=False)
                    file_exists = True

# Main execution
# if __name__ == "__main__":
#     models = ["llama3.3:70b"]  # Add more models as needed
#     #"gpt-4.5-preview-2025-02-27", "llama3", "mistral-small", "deepseek-r1", "qwen3", "llama3.3:latest", "deepseek-r1:7b", "mixtral:8x7b", "qwen3:32b"
#     version = "cooperation_loss"  # "classic" or "high", "mild", "cooperation_loss"
#     anonymised = False # True or False
#     temperature = 0.7
#     iterations = 30
#     output_file = f"data/pd/pd.{version}.{anonymised}.csv"
#     experiment = PDExperiment(
#         models=models,
#         version =version,
#         anonymised = anonymised,
#         temperature=temperature,
#         iterations=iterations,
#         output_file=output_file
#     )
#     asyncio.run(experiment.run_experiment())
#     print(f"All experiment results saved to {output_file}")
# Main execution
if __name__ == "__main__":
    models = ["mixtral:8x7b"]
    versions = ["classic", "high", "mild", "cooperation_loss"]
    anonymised_options = [True, False]
    temperature = 0.7
    iterations = 30
    for version in versions:
        for anonymised in anonymised_options:
            output_file = f"data/pd/pd.{version}.{anonymised}.csv"
            experiment = PDExperiment(
                models=models,
                version=version,
                anonymised=anonymised,
                temperature=temperature,
                iterations=iterations,
                output_file=output_file
            )
            asyncio.run(experiment.run_experiment())
            print(f"All experiment results saved to {output_file}")