"""
Visualize bounce statistics from a saved metric-graph NPZ.

Outputs (under settings.plot_dir):
  - bounce_stats.png : histogram of per-particle bounce counts (log bins), with rates annotated.
"""

from pathlib import Path

import os
import matplotlib

matplotlib.use("Agg")
import matplotlib.pyplot as plt
import numpy as np
from gitbud.gitbud import inject_repo_into_sys_path

inject_repo_into_sys_path()

from experiments.dumux_tracer.config_loader import load_settings


def main() -> None:
    settings = load_settings()
    override = os.environ.get("DUMUX_METRIC_OUTPUT")
    path = Path(override) if override else settings.metric_output
    data = np.load(path)

    # Prefer saved histogram; fall back to summary stats if needed.
    hist_counts = np.asarray(data.get("bounce_hist_counts", []), dtype=int)
    hist_edges = np.asarray(data.get("bounce_hist_edges", []), dtype=float)
    mean = float(data.get("bounces_mean", 0.0))
    median = float(data.get("bounces_median", 0.0))
    p90 = float(data.get("bounces_p90", 0.0))
    p99 = float(data.get("bounces_p99", 0.0))
    rate_step = float(data.get("bounce_rate_per_substep", 0.0))
    rate_kernel = float(data.get("bounce_rate_per_kernel", 0.0))
    steps = int(data.get("steps", 0))
    dt = float(data.get("dt", 0.0))

    fig, ax = plt.subplots(figsize=(6, 4))
    if hist_counts.size and hist_edges.size:
        ax.bar(hist_edges[:-1], hist_counts, width=np.diff(hist_edges), align="edge", alpha=0.7)
        ax.set_xlabel("Avg bounces per sub-step (per particle)")
        ax.set_ylabel("Count")
        ax.set_title("Bounce histogram (per-substep)")
    else:
        ax.text(0.5, 0.5, "No histogram stored", ha="center", va="center", transform=ax.transAxes)
        ax.axis("off")

    # Light title with key rates (no overlay text)
    ax.set_title(
        f"Bounce histogram | mean={mean:.2e}, per-substep={rate_step:.3f}, dt={dt:.1e}, steps={steps}",
        fontsize=10,
    )
    fig.tight_layout()

    out = Path(settings.plot_dir) / "bounce_stats.png"
    out.parent.mkdir(parents=True, exist_ok=True)
    fig.savefig(out, dpi=200)
    plt.close(fig)
    print(f"[bounce stats] wrote {out}")


if __name__ == "__main__":
    main()
