"""
Visualize the preprocessed network with original vertices and cell boundaries.
- Original graph vertices: red scatter
- Cell-cell boundaries: blue scatter (smaller)
"""

from pathlib import Path

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 import config as dumux_config


def main() -> None:
    data = np.load(dumux_config.input_path)
    orig_points = np.asarray(data["orig_points"], dtype=float)
    cell_points = np.asarray(data["cell_points"], dtype=float)
    orig_edges = np.asarray(data["orig_edges"], dtype=int)

    fig, ax = plt.subplots(figsize=(6, 6))
    # Draw edges (original connectivity)
    for u, v in orig_edges:
        ax.plot(
            [orig_points[u, 0], orig_points[v, 0]],
            [orig_points[u, 1], orig_points[v, 1]],
            color="black",
            linewidth=0.6,
            alpha=0.6,
        )

    ax.scatter(orig_points[:, 0], orig_points[:, 1], s=6, color="red", alpha=0.8, label="original vertices")
    ax.scatter(
        cell_points[:, 0],
        cell_points[:, 1],
        s=3,
        color="blue",
        alpha=0.35,
        marker="x",
        linewidths=0.5,
        label="cell boundaries",
    )
    ax.set_aspect("equal", adjustable="datalim")
    ax.set_xticks([])
    ax.set_yticks([])
    ax.legend(loc="upper right", markerscale=2)
    ax.set_title(
        f"Original vertices (red, n={orig_points.shape[0]}) vs cell boundaries (blue, n={cell_points.shape[0]})"
    )
    out_path = Path("figs") / "dumux_cells_vs_vertices.png"
    out_path.parent.mkdir(parents=True, exist_ok=True)
    fig.tight_layout()
    fig.savefig(out_path, dpi=200)
    plt.close(fig)
    print(f"[plot] wrote {out_path}")


if __name__ == "__main__":
    main()
