


import pandas as pd
import matplotlib.pyplot as plt
import matplotlib


matplotlib.rcParams['font.family'] = 'Arial'
matplotlib.rcParams['axes.unicode_minus'] = False
plt.rc('font', size=14)
plt.rc('axes', titlesize=18, labelsize=16)
plt.rc('xtick', labelsize=18)
plt.rc('ytick', labelsize=18)
plt.rc('legend', fontsize=18)
plt.rc('figure', titlesize=22)


try:

    plot_data = [
        {
            "title": "10*10 3U7O",
            "no_oel_y": 0.7,
            "oel_file": "1s3c1010_3_yes.csv",
            "y_min": 0.65
        },
        {
            "title": "10*10 5U7O",
            "no_oel_y": 0.5833333134651184,
            "oel_file": "1s3c1010_5_yes.csv",
            "y_min": 0.5333333134651184
        },
        {
            "title": "10*10 7U7O",
            "no_oel_y": 0.5,
            "oel_file": "1s3c1010_7_yes.csv",
            "y_min": 0.45
        }
    ]

    fig, axes = plt.subplots(1, len(plot_data), figsize=(14, 4.5))
    if len(plot_data) == 1:
        axes = [axes]

    COLORS = {'OEL': '#D55E00', 'No OEL': '#0072B2'}
    LINE_WIDTH = 2.5

    handles, labels = [], []


    for i, group in enumerate(plot_data):
        ax = axes[i]

        line_no_oel = ax.axhline(
            y=group["no_oel_y"],
            color=COLORS['No OEL'],
            linestyle='-',
            linewidth=LINE_WIDTH,
            label='No OEL'
        )

        df = pd.read_csv(group["oel_file"])
        df_filtered = df[df['Step'] <= 100].copy()
        df_smooth = df_filtered['Value'].rolling(window=10, min_periods=1, center=True).mean()
        line_oel, = ax.plot(df_filtered['Step'], df_smooth,
                            color=COLORS['OEL'],
                            linestyle='-',
                            linewidth=LINE_WIDTH,
                            label='OEL')

        if not handles:
            handles = [line_no_oel, line_oel]
            labels = ['No OEL', 'OEL']

        ax.set_title(f"{group['title']}", fontweight='bold',fontsize=22)
        ax.grid(True, which='both', linestyle='--', linewidth=0.5, color='lightgray', alpha=0.6)
        ax.set_xlim(-2, 102)
        ax.set_ylim(bottom=group["y_min"])

        if i == 0:
            ax.set_ylabel('Accuracy', fontweight='bold', fontsize=20)

    fig.legend(handles, labels, loc='lower center', ncol=2, frameon=False)
    fig.text(0.5, 0.16, 'Episodes', ha='center', va='center', fontweight='bold', fontsize=20)

    fig.tight_layout(rect=[0, 0.18, 1, 0.97])
    plt.subplots_adjust(wspace=0.25)

    plt.savefig('Performance_Comparison.png', dpi=300, bbox_inches='tight')
    plt.savefig('Performance_Comparison.pdf', bbox_inches='tight')
    plt.show()

except FileNotFoundError as e:
    print(f"cannot find file '{e.filename}'")
except Exception as e:
    print(f"error: {e}")



