import matplotlib.pyplot as plt
import pandas as pd


label_fontsize = 30 
tick_fontsize = 25  
legend_fontsize = 20  


plt.rcParams['font.family'] = 'Times New Roman'  


file_paths = [
    'results_else/SingleRun_CNN_MNIST_R_60.csv', 
    'results_else/SingleRun_CIFAR_R_60.csv'
]
dfs = [pd.read_csv(file_path) for file_path in file_paths]


cases_list = [df['case'].unique() for df in dfs]


labels = ['CNN-MNIST', 'CNN-CIFAR10']


plt.figure(figsize=(10, 5))
for i, df in enumerate(dfs):

    if df['case'].isnull().all():
        case_data = df.iloc[:80]  
        plt.plot(range(len(case_data)), case_data['lossValue'], label=f'{labels[i]} ')
    else:
        for j, case in enumerate(cases_list[i]):
            case_data = df[df['case'] == case].iloc[:80]  
            plt.plot(range(len(case_data)), case_data['lossValue'], label=f'{labels[i]} - Case {j + 1}')

plt.xlabel('Interation T', fontsize=label_fontsize) 
plt.ylabel('Loss Value', fontsize=label_fontsize)


plt.xticks(fontsize=tick_fontsize)
plt.yticks(fontsize=tick_fontsize)


plt.legend(fontsize=legend_fontsize)


plt.grid(True)


plt.tight_layout()


plt.savefig('loss_plot_rounds_80.png', dpi=300, bbox_inches='tight')
plt.savefig('loss_plot_rounds_80.svg', format='svg', bbox_inches='tight')  
plt.savefig('loss_plot_rounds_80.pdf', format='pdf', bbox_inches='tight')  
plt.show()


plt.figure(figsize=(10, 5))
for i, df in enumerate(dfs):

    if df['case'].isnull().all():
        case_data = df.iloc[:80]  
        plt.plot(range(len(case_data)), case_data['predictionAccuracy'], label=f'{labels[i]} ')
    else:
        for j, case in enumerate(cases_list[i]):
            case_data = df[df['case'] == case].iloc[:80]  
            plt.plot(range(len(case_data)), case_data['predictionAccuracy'], label=f'{labels[i]} - Case {j + 1}')

plt.xlabel('Interation T', fontsize=label_fontsize)  
plt.ylabel('Prediction Accuracy', fontsize=label_fontsize)


plt.xticks(fontsize=tick_fontsize)
plt.yticks(fontsize=tick_fontsize)


plt.legend(fontsize=legend_fontsize)


plt.grid(True)

plt.tight_layout()


plt.savefig('accuracy_plot_rounds_80.png', dpi=300, bbox_inches='tight')
plt.savefig('accuracy_plot_rounds_80.svg', format='svg', bbox_inches='tight')  
plt.savefig('accuracy_plot_rounds_80.pdf', format='pdf', bbox_inches='tight')  
plt.show()
