import matplotlib.pyplot as plt
import numpy as np

# 设置matplotlib支持中文和学术风格
plt.rcParams['font.family'] = ['Times New Roman', 'DejaVu Serif']
plt.rcParams['font.size'] = 12
plt.rcParams['axes.linewidth'] = 1.2
plt.rcParams['grid.linewidth'] = 0.8
plt.rcParams['grid.alpha'] = 0.3

# DP算法数据 (PSNR = 8.57)
dp_data = [
    0.2053999900817871, 0.29839998483657837, 0.3351999819278717, 0.3799999952316284, 0.375,
    0.4505999982357025, 0.44200000166893005, 0.47759997844696045, 0.40379998087882996, 0.3118000030517578,
    0.35839998722076416, 0.37299999594688416, 0.3463999927043915, 0.3229999840259552, 0.30539998412132263,
    0.30379998683929443, 0.28779998421669006, 0.295199990272522, 0.2821999788284302, 0.2897999882698059,
    0.2913999855518341, 0.2751999795436859, 0.25619998574256897, 0.2531999945640564, 0.2541999816894531,
    0.2483999878168106, 0.2441999912261963, 0.22939999401569366, 0.2199999988079071, 0.20799998939037323,
    0.21799999475479126, 0.21480000019073486, 0.21299999952316284, 0.21559999883174896, 0.22179999947547913,
    0.21779999136924744, 0.22059999406337738, 0.21679998934268951, 0.19859999418258667, 0.2141999900341034,
    0.20019999146461487, 0.19299998879432678, 0.20479999482631683, 0.19499999284744263, 0.2029999941587448,
    0.1891999989748001, 0.18479999899864197, 0.1770000010728836, 0.20719999074935913
]

# FedRPF算法数据 (PSNR = 8.53)
fedrpf_data = [
    0.2053999900817871, 0.29839998483657837, 0.3351999819278717, 0.3799999952316284, 0.375,
    0.4505999982357025, 0.44200000166893005, 0.47759997844696045, 0.2669999897480011, 0.3224000036716461,
    0.3489999771118164, 0.37439998984336853, 0.3677999973297119, 0.35979998111724854, 0.3946000039577484,
    0.3789999783039093, 0.4027999937534332, 0.3879999816417694, 0.37359997630119324, 0.4105999767780304,
    0.41359999775886536, 0.420199990272522, 0.3856000006198883, 0.42319998145103455, 0.4023999869823456,
    0.4139999747276306, 0.4315999746322632, 0.4333999752998352, 0.41119998693466187, 0.4245999753475189,
    0.4267999827861786, 0.4413999915122986, 0.4285999834537506, 0.42659997940063477, 0.4311999976634979,
    0.4327999949455261, 0.43359997868537903, 0.42579999566078186, 0.44339999556541443, 0.4429999887943268,
    0.4341999888420105, 0.4405999779701233, 0.43699997663497925, 0.4373999834060669, 0.41579997539520264,
    0.4333999752998352, 0.43039998412132263, 0.44200000166893005, 0.4244000017642975
]

# 训练轮数
rounds = list(range(len(dp_data)))

# 创建图形和坐标轴
fig, ax = plt.subplots(figsize=(10, 6))

# 绘制曲线
line1 = ax.plot(rounds, dp_data, 
                linewidth=2.5, 
                color='#E74C3C', 
                marker='o', 
                markersize=4,
                markerfacecolor='#E74C3C',
                markeredgecolor='white',
                markeredgewidth=1,
                label='DP Algorithm (PSNR = 8.57)',
                alpha=0.9)

line2 = ax.plot(rounds, fedrpf_data, 
                linewidth=2.5, 
                color='#3498DB', 
                marker='s', 
                markersize=4,
                markerfacecolor='#3498DB',
                markeredgecolor='white',
                markeredgewidth=1,
                label='FedRPF Algorithm (PSNR = 8.53)',
                alpha=0.9)

# 设置坐标轴标签
ax.set_xlabel('Training Round', fontsize=14, fontweight='bold')
ax.set_ylabel('Accuracy', fontsize=14, fontweight='bold')

# 设置标题
ax.set_title('Accuracy Comparison: DP vs FedRPF Algorithm', 
             fontsize=16, fontweight='bold', pad=20)

# 设置网格
ax.grid(True, linestyle='-', alpha=0.3, color='gray')
ax.set_axisbelow(True)

# 设置坐标轴范围
ax.set_xlim(-1, 50)
ax.set_ylim(0.15, 0.50)

# 设置刻度
ax.set_xticks(np.arange(0, 51, 5))
ax.set_yticks(np.arange(0.15, 0.51, 0.05))

# 格式化y轴刻度标签
ax.yaxis.set_major_formatter(plt.FuncFormatter(lambda x, p: f'{x:.3f}'))

# 设置图例
legend = ax.legend(loc='upper right', 
                   frameon=True, 
                   fancybox=True, 
                   shadow=True,
                   framealpha=0.9,
                   fontsize=12)
legend.get_frame().set_facecolor('white')
legend.get_frame().set_edgecolor('gray')

# 调整布局
plt.tight_layout()

# 显示图形
plt.show()

# 可选：保存图形
# plt.savefig('accuracy_comparison.png', dpi=300, bbox_inches='tight', 
#             facecolor='white', edgecolor='none')
plt.savefig('./Plot/accuracy_comparison.pdf', bbox_inches='tight', 
            facecolor='white', edgecolor='none')

# 打印一些统计信息
print("=" * 50)
print("算法性能统计:")
print("=" * 50)
print(f"DP算法:")
print(f"  最大准确率: {max(dp_data):.4f} (第{dp_data.index(max(dp_data))}轮)")
print(f"  最小准确率: {min(dp_data):.4f} (第{dp_data.index(min(dp_data))}轮)")
print(f"  平均准确率: {np.mean(dp_data):.4f}")
print(f"  标准差: {np.std(dp_data):.4f}")

print(f"\nFedRPF算法:")
print(f"  最大准确率: {max(fedrpf_data):.4f} (第{fedrpf_data.index(max(fedrpf_data))}轮)")
print(f"  最小准确率: {min(fedrpf_data):.4f} (第{fedrpf_data.index(min(fedrpf_data))}轮)")
print(f"  平均准确率: {np.mean(fedrpf_data):.4f}")
print(f"  标准差: {np.std(fedrpf_data):.4f}")

print(f"\n性能对比:")
print(f"  FedRPF相对DP的平均准确率提升: {(np.mean(fedrpf_data) - np.mean(dp_data))/np.mean(dp_data)*100:.2f}%")
print(f"  FedRPF稳定性优势(标准差比较): {(np.std(dp_data) - np.std(fedrpf_data))/np.std(dp_data)*100:.2f}%")