import pandas as pd
import os
import json
import csv
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.patches import Rectangle
import numpy as np

# === Set matplotlib font sizes globally ===
plt.rcParams.update({
    'axes.titlesize': 26,
    'axes.labelsize': 22,
    'xtick.labelsize': 20,
    'ytick.labelsize': 20,
    'legend.fontsize': 10,
    'figure.titlesize': 26,
})

# === Load config ===
with open("config/config.json", "r") as f:
    config = json.load(f)
base_dir = config['data_folder']

# === Define paths ===
csv_path = os.path.join(base_dir, "results_test", "combination_internal_test", "final_modelwise_coverage_accuracy_results.csv")
output_dir = os.path.join(base_dir, "results_test", "plot_combinations")
os.makedirs(output_dir, exist_ok=True)

# === Load CSV with delimiter auto-detection ===
with open(csv_path, "r", encoding='utf-8-sig') as f:
    sample = f.read(2048)
    f.seek(0)
    dialect = csv.Sniffer().sniff(sample)
    print(f"Detected delimiter: {repr(dialect.delimiter)}")
    df = pd.read_csv(f, delimiter=dialect.delimiter)

# === Clean and sort dataframe ===
df.columns = df.columns.str.strip()
df = df.sort_values(by="mean_subset_coverage")
print("Columns:", df.columns.tolist())

# === Plotting parameters ===
fill_color = "steelblue"

# === Prepare legend handle (only one label) ===
legend_handles = []
legend_labels = []

# === Plot ===
for model_idx, (model_name, model_df) in enumerate(df.groupby("model")):
    fig, ax = plt.subplots(figsize=(10, 6))

    for _, row in model_df.iterrows():
        x = row["mean_subset_coverage"]
        y = row["mean_accuracy"]
        x_err = row["std_subset_coverage"]
        y_err = row["std_accuracy"]

        # Transparent filled rectangle (1 std)
        filled_rect = Rectangle(
            (x - x_err, y - y_err),
            2 * x_err,
            2 * y_err,
            facecolor=fill_color,
            edgecolor=None,
            alpha=0.3,
            zorder=1
        )
        ax.add_patch(filled_rect)

        # Outline rectangle (1 std)
        edge_rect = Rectangle(
            (x - x_err, y - y_err),
            2 * x_err,
            2 * y_err,
            facecolor='none',
            edgecolor=fill_color,
            linestyle='--',
            linewidth=1,
            zorder=2
        )
        ax.add_patch(edge_rect)

        # Central dot
        ax.plot(x, y, 'o', color=fill_color, markersize=4, zorder=3)

    # Add legend entry only once
    if model_idx == 0:
        dot_handle = ax.plot([], [], 'o', color=fill_color, markersize=4, label="Confidence Curve")[0]
        legend_handles.append(dot_handle)
        legend_labels.append("Confidence Curve")

    ax.set_xlabel("Coverage Target")
    ax.set_ylabel("Mean Accuracy")
    ax.grid(True, linestyle=":", linewidth=0.8)
    fig.tight_layout()

    save_path = os.path.join(output_dir, f"{model_name}_accuracy_vs_coverage.png".replace("/", "_"))
    fig.savefig(save_path, dpi=300)
    plt.close(fig)
    print(f"Saved: {save_path}")

# === Shared legend plot ===
fig_legend = plt.figure(figsize=(12, 1))
fig_legend.legend(
    handles=legend_handles,
    labels=legend_labels,
    loc='center',
    ncol=2,
    fontsize=10,
    frameon=False
)
legend_path = os.path.join(output_dir, "shared_legend.png")
fig_legend.tight_layout()
fig_legend.savefig(legend_path, dpi=300, bbox_inches='tight')
print(f"Legend saved as: {legend_path}")
