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 acc_by_ds(data, ds_name):
    subset = data[data["ds"] == ds_name]
    acc = (
        subset.groupby("model")["correct"]
        .mean()
        .reset_index(name=f"accuracy_{ds_name}")
    )
    return acc
# Compute macro accuracy for simpleV and complexV
macro_simple = acc_by_ds(df, "simpleV")
macro_complex = acc_by_ds(df, "complexV")

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

print (macro_both.columns)

# Convert to percentages
for col in ["accuracy_simpleV", "accuracy_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("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: accuracy_by_model.md")