import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
import sys
import os

sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
from utils.plots import set_plt

set_plt()

data = np.load("results/coco_l2_norms.npz", allow_pickle=True)
norms = data["norms"]
mean, std = norms.mean(), norms.std()

plt.figure(figsize=(8, 5))
sns.histplot(data=norms, stat="density", bins=50, color="#2196F3", alpha=0.6)
plt.xlabel("L2 Norm")
plt.ylabel("Density")
plt.title("Distribution of COCO Caption Embedding L2 Norms")

# Add mean and std text
plt.text(
    0.98,
    0.95,
    f"μ = {mean:.2f}\nσ = {std:.2f}",
    transform=plt.gca().transAxes,
    horizontalalignment="right",
    verticalalignment="top",
    bbox=dict(facecolor="white", alpha=0.8, edgecolor="none"),
)

plt.tight_layout()
plt.savefig("plots/out/coco_l2_norms.pdf", bbox_inches="tight")
plt.show()

print(f"Mean: {mean:.2f}")
print(f"Std: {std:.2f}")
