import matplotlib.pyplot as plt
import pandas as pd
import numpy as np
import os

def plot_radius_effects():
    """
    Loads data from the radius experiment and creates plots to visualize the effect
    of the initialization radius 'r' on the three measured potentials.
    """
    # --- Configuration (should match the generation script) ---
    n = 1000 # Using n=1200 as per user request in previous turns
    K = 2
    s_n = 1
    # Define the range of initialization radii to test with symbolic labels
    r_labels = [
        (1/n**2, r'$1/n^2$'),
        (1/n, r'$1/n$'),
        (1/np.sqrt(n), r'$1/\sqrt{n}$'),
        (1.0, r'$1$')
    ]
    
    data_dir = "../dat"
    img_dir = "../img"
    os.makedirs(img_dir, exist_ok=True)

    # --- Plotting Setup ---
    # plt.style.use('seaborn-v0_8-darkgrid')
    fig, axes = plt.subplots(1, 2, figsize=(21, 6)) # Corrected to 1 row, 3 columns

    # --- Plot 1: Alignment with u_1 (Global Mean) ---
    ax1 = axes[0]
    for r_val, r_label in r_labels:
        # Use the label for the filename, replacing problematic characters
        safe_r_label = r_label.replace('/', '_').replace('$', '').replace('\\', '').replace('{', '').replace('}', '')
        filename = os.path.join(data_dir, f"potentials_n{n}_K{K}_sn{s_n}_r{safe_r_label}.csv")
        if os.path.exists(filename):
            df = pd.read_csv(filename)
            df_filtered = df[df['iteration'] <= 40_000_000]
            ax1.plot(df_filtered['iteration'], 1 - df_filtered['community_potential'], label=r_label) # Use string label

    # ax1.set_title("Alignment with $u_1$ (Global Mean)", fontsize=14)
    ax1.set_xlabel("Iteration (t)", fontsize=12)
    ax1.set_ylabel("1 - $\Vert \Pi x \Vert^2 / \Vert x \Vert^2$", fontsize=12)
    ax1.legend(title="Init Radius (r)")
    ax1.grid(True, which='major', linestyle='--', alpha=0.7)

    # --- Plot 2: Community Alignment (Log-Linear Plot) ---
    ax2 = axes[1]
    for r_val, r_label in r_labels:
        safe_r_label = r_label.replace('/', '_').replace('$', '').replace('\\', '').replace('{', '').replace('}', '')
        filename = os.path.join(data_dir, f"potentials_n{n}_K{K}_sn{s_n}_r{safe_r_label}.csv")
        if os.path.exists(filename):
            df = pd.read_csv(filename)
            df_filtered = df[df['iteration'] <= 40_000_000]
            log_error = 1 - df_filtered['community_potential']
            log_error = log_error.clip(lower=1e-12) 
            ax2.plot(df_filtered['iteration'], log_error, label=r_label) # Use string label

    ax2.set_yscale('log')
    # ax2.set_title("Convergence of Community Alignment", fontsize=14)
    ax2.set_xlabel("Iteration (t)", fontsize=12)
    ax2.set_ylabel("$\log{(1 - \Vert \Pi x \Vert^2 / \Vert x \Vert^2)}$", fontsize=12)
    ax2.legend(title="Init Radius (r)")
    ax2.grid(True, which='both', linestyle='--', alpha=0.7)

    # --- Final Touches ---
    plt.tight_layout(rect=[0, 0.03, 1, 0.95])
    # fig.suptitle(f"Effect of Initialization Radius 'r' (n={n}, K={K}, s_n={s_n})", y=0.98, fontsize=18, weight='bold')

    output_filename = os.path.join(img_dir, f"radius_effect_n{n}_K{K}_sn{s_n}.eps")
    plt.savefig(output_filename, format='eps', bbox_inches='tight')
    print(f"Plot saved to {output_filename}")

if __name__ == "__main__":
    plot_radius_effects()
