import pandas as pd

# Read your metric CSV
df = pd.read_csv("metric_data.csv")

# Drop unwanted asset if needed
df = df[df["asset_type"] != "AHU Humidity"]

# Function to compute macro accuracy per model for a given dataset
def macro_acc_by_ds(data, ds_name):
    subset = data[data["ds"] == ds_name]
    per_asset = subset.groupby(["model", "asset_type"])["correct"].mean().reset_index(name="accuracy")
    macro_acc = per_asset.groupby("model")["accuracy"].mean().reset_index(name=f"macro_acc_{ds_name}")
    return macro_acc

# Compute macro accuracy for simpleV and complexV
macro_simple = macro_acc_by_ds(df, "simpleV")
macro_complex = macro_acc_by_ds(df, "complexV")

# Merge side by side
macro_both = pd.merge(macro_simple, macro_complex, on="model", how="outer")

# Convert to percentages
for col in ["macro_acc_simpleV", "macro_acc_complexV"]:
    macro_both[col] = (macro_both[col] * 100).round(2).astype(str) + "%"

# Markdown output
md_output = macro_both.to_markdown(index=False)

# Save to file
with open("macro_accuracy_by_model.md", "w") as f:
    f.write("# Macro-Averaged Accuracy by Model for SimpleV and ComplexV\n\n")
    f.write(md_output)

print("Markdown file created: macro_accuracy_by_model.md")
