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


D = torch.load('Times.pt', weights_only=False)

delta_rgbs = [5,10,15]
    


D = torch.load('Times.pt', weights_only = False)

avg_times = D['Tbs']

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

xtick_labels = [f"${d} / 255$" for d in delta_rgbs]
plt.xlabel("Radius of $\ell_\infty$ perturbation over entire image", fontsize=12)
plt.ylabel("Average Verification Runtime (seconds)", fontsize=12)
plt.ylim(300, 1200)
plt.legend(fontsize=10)
plt.gca().yaxis.set_major_formatter(ScalarFormatter(useOffset=False))
plt.title("Average Verification Runtime vs 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("Runtim_vs_Perturbation.png", dpi=300)  # Save high-res for paper
plt.savefig("Runtime_vs_Perturbation.eps", format='eps')
plt.show()
