"""
Plot a simple runtime bar chart for DuMuX vs CUDA metric-graph run.

Inputs:
    - DUMUX_MG_OUTPUT (env): path to metric NPZ (default data/dumux_metric_graph_sim.npz)
    - DUMUX_RUNTIME_FILE (env): optional text file containing a single runtime value in seconds.
      Defaults to <DUMUX_TRACER_OUTPUT basename>_runtime.txt produced by the dumux-run target.

Outputs:
    - figs/dumux_metric_runtime.png
"""

import os
from pathlib import Path

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

settings = load_settings()
REPO_ROOT = Path(inject_repo_into_sys_path())


def _env_path(name: str, default: Path) -> Path:
    raw = os.environ.get(name)
    return Path(raw) if raw else default


def _load_dumux_runtime() -> float | None:
    # File with a single number (defaults to module-derived path)
    runtime_file = _env_path("DUMUX_RUNTIME_FILE", settings.dumux_runtime_file)
    if runtime_file.exists():
        try:
            return float(runtime_file.read_text().strip().split()[0])
        except Exception:
            pass
    return None


def _load_metric_runtime(metric_npz: Path) -> float | None:
    data = np.load(metric_npz)
    if "total_wall_time" in data:
        return float(data["total_wall_time"])
    return None


def main() -> None:
    metric_npz = _env_path("DUMUX_MG_OUTPUT", settings.metric_output)
    dumux_runtime = _load_dumux_runtime()
    metric_runtime = _load_metric_runtime(metric_npz)

    labels = []
    values = []
    colors = []

    if dumux_runtime is not None:
        labels.append("DuMuX FVM")
        values.append(dumux_runtime)
        colors.append("C1")
    if metric_runtime is not None:
        labels.append("CUDA MG")
        values.append(metric_runtime)
        colors.append("C0")

    if not values:
        print("[runtime plot] No runtime data available; ensure runtime file exists or metric NPZ has total_wall_time.")
        return

    fig, ax = plt.subplots(figsize=(4, 4))
    ax.bar(labels, values, color=colors)
    ax.set_ylabel("Wall time (s)")
    ax.set_title("Runtime comparison")
    # Annotate bars and speedup if both present.
    for i, v in enumerate(values):
        ax.text(i, v, f"{v:.2f}s", ha="center", va="bottom", fontsize=9)
    if len(values) == 2:
        speedup = values[0] / values[1] if values[1] > 0 else float("nan")
        ax.text(
            0.5,
            max(values) * 1.05,
            f"speedup ≈ {speedup:.2f}×",
            ha="center",
            va="bottom",
            fontsize=10,
        )
    fig.tight_layout()
    base_dir = os.environ.get("DUMUX_PLOT_DIR") or os.environ.get("RUNTIME_PLOT_DIR") or settings.plot_dir
    out_dir = Path(base_dir)
    out_dir.mkdir(parents=True, exist_ok=True)
    out = out_dir / "dumux_metric_runtime.png"
    out.parent.mkdir(parents=True, exist_ok=True)
    fig.savefig(out, dpi=200)
    plt.close(fig)
    print(f"[runtime plot] wrote {out}")


if __name__ == "__main__":
    main()
