import torch
import matplotlib.pyplot as plt
from matplotlib.ticker import ScalarFormatter

D = torch.load('Results.pt', weights_only=False)
RV_bars = D['RV_bars']
# IoU_bars = D['IoU_bars']


delta_rgbs = [50,100,150]


# --- Plotting ---
plt.figure(figsize=(6, 4))
plt.plot(delta_rgbs, RV_bars, marker='o', linestyle='-', color='tab:blue', linewidth=2, markersize=6, label = 'BiSeNet for CamVid')

xtick_labels = [f"${d / 255:.5}$" for d in delta_rgbs]

plt.xlabel("Radius of $\ell_2$ perturbation over entire image", fontsize=12)
plt.ylabel("Average Robustness Value ($\\overline{\\mathbf{RV}}$)", fontsize=12)
plt.legend(fontsize=10)
plt.gca().yaxis.set_major_formatter(ScalarFormatter(useOffset=False))
plt.title("Average Robustness Value vs $\ell_2$ Perturbation Level", fontsize=13)
plt.grid(True, linestyle='--', linewidth=0.5, alpha=0.7)
plt.xticks(delta_rgbs, xtick_labels, fontsize=10)
plt.yticks(fontsize=10)
plt.tight_layout()
plt.savefig("Robustness_vs_Perturbation.png", dpi=300)  # Save high-res for paper
plt.savefig("Robustness_vs_Perturbation.eps", format='eps')
plt.show()
