import pandas as pd
from src.pd.role import Role

def process_experiment_results(version: str, anonymised: bool):
    """Loads experiment results, calculates cooperation rate, reorders columns, and saves to CSV."""
    # Load the experiment results
    df = pd.read_csv(f"../../data/pd/pd.{version}.{anonymised}.csv")
    # Calculate the cooperation rate by model and belief
    cooperation_table = (1- df.groupby(["Model", "Role"])["Rationality"].mean()).unstack()
    # Reorder the columns in the desired order
    desired_order = ["RATIONAL", "NEUTRAL", "HUMAN"]
    cooperation_table = cooperation_table.reindex(columns=desired_order)
    # Display the table
    print(f"Cooperation for version {version} and anonymised {anonymised}\n")
    print(cooperation_table)
    # Save the table as a CSV file for future use
    cooperation_table.to_csv(f"../../figures/pd/pd_cooperation.{version}.{anonymised}.csv")

# Process all versions
for version in ["classic", "high", "mild", "cooperation_loss"]:
    for anonymised in [False, True]:
        process_experiment_results(version, anonymised)
