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

def plot_subplot(ax, s_n, K_values, n, data_dir):
    """
    Plots community potential for a given s_n and a list of K values on a specific subplot axis.
    """
    for K in K_values:
        filename = os.path.join(data_dir, f"potentials_s{s_n}_n{n}_K{K}.csv")
        
        if os.path.exists(filename):
            try:
                df = pd.read_csv(filename)
                if "community_potential" in df.columns:
                    ax.plot(df["iteration"], df["community_potential"], label=f"K={K}")
                else:
                    print(f"Warning: 'community_potential' column not found in {filename}")
            except Exception as e:
                print(f"Error reading or plotting {filename}: {e}")
        else:
            print(f"Warning: Data file not found: {filename}")
            
    ax.set_title(f"$s_n = {s_n}$", fontsize=14)
    ax.set_xlabel("Iteration (t)", fontsize=12)
    # ax.set_ylabel("Community Potential", fontsize=12)
    ax.set_ylabel("$\Vert \Pi x \Vert^2 / \Vert x \Vert^2$", fontsize=12)
    ax.legend(title="Clusters (K)")
    ax.grid(True, linestyle='--', alpha=0.6)

def main():
    """
    Main function to create and save the publication-quality plot.
    """
    # --- Publication Quality Settings ---
    plt.rcParams['text.color'] = 'black'
    plt.rcParams['axes.labelcolor'] = 'black'
    plt.rcParams['xtick.color'] = 'black'
    plt.rcParams['ytick.color'] = 'black'
    plt.rcParams['ps.fonttype'] = 42
    plt.rcParams['pdf.fonttype'] = 42

    # --- Main Configuration ---
    n = 1200
    data_dir = "../dat"
    img_dir = "../img"

    # Ensure the image directory exists
    os.makedirs(img_dir, exist_ok=True)
    
    # Define the configurations for the 1x4 plot
    plot_configs = [
        {'s_n': 1, 'K': [2, 3, 4], 'xlim': None},
        {'s_n': 2, 'K': [2, 3, 4], 'xlim': 20_000_000},
        {'s_n': 5, 'K': [2, 3, 4], 'xlim': 10_000_000},
        {'s_n': 10, 'K': [2, 3, 4], 'xlim': 10_000_000}
    ]

    # plt.style.use('seaborn-v0_8-darkgrid')
    fig, axes = plt.subplots(1, 4, figsize=(24, 6)) # Removed sharey=True

    for i, config in enumerate(plot_configs):
        plot_subplot(axes[i], config['s_n'], config['K'], n, data_dir)
        if config['xlim'] is not None:
            axes[i].set_xlim(0, config['xlim'])
    
    # Remove individual y-axis labels for shared axes to de-clutter
    for ax in axes.flat[1:]:
        ax.set_ylabel('')

    # Removed the loop that set ylabel to ''
    plt.tight_layout()
    # fig.suptitle(...) # Removed as per user request

    # Save the plot as EPS
    output_filename = os.path.join(img_dir, f"community_potentials_n{n}_comparison.eps")
    plt.savefig(output_filename, format='eps', bbox_inches='tight')
    print(f"Plot saved to {output_filename}")
    
    # plt.show() # Uncomment to display the plot interactively

if __name__ == "__main__":
    main()
