"""
Simple stats for the DuMuX network: connected components and basic geometry.
"""

import numpy as np
from gitbud.gitbud import inject_repo_into_sys_path
from pathlib import Path

inject_repo_into_sys_path()

from experiments.dumux_tracer.config import config


def connected_components(n_nodes: int, edges: np.ndarray) -> list[list[int]]:
    adj = [[] for _ in range(n_nodes)]
    for u, v in edges:
        adj[u].append(v)
        adj[v].append(u)
    visited = [False] * n_nodes
    comps: list[list[int]] = []
    for start in range(n_nodes):
        if visited[start]:
            continue
        stack = [start]
        comp = []
        visited[start] = True
        while stack:
            u = stack.pop()
            comp.append(u)
            for nbr in adj[u]:
                if not visited[nbr]:
                    visited[nbr] = True
                    stack.append(nbr)
        comps.append(comp)
    return comps


def main() -> None:
    data = np.load(config.output_path)
    edges = np.asarray(data["cell_edges"], dtype=int)
    points = np.asarray(data["cell_points"], dtype=float)
    tracer = np.asarray(data["tracer"], dtype=float)
    components = connected_components(points.shape[0], edges)
    comp_edges = []
    for comp in components:
        mask = np.isin(edges[:, 0], comp) | np.isin(edges[:, 1], comp)
        comp_edges.append(np.nonzero(mask)[0])

    final_mass = tracer[-1]
    print(f"[dumux stats] nodes={points.shape[0]}, edges={edges.shape[0]}")
    print(f"[dumux stats] connected components: {len(components)}")
    for idx, comp in enumerate(components):
        e_idx = comp_edges[idx]
        mass = final_mass[e_idx].sum()
        print(f"  component {idx}: nodes={len(comp):4d}, edges={len(e_idx):4d}, final mass={mass:.4e}")


if __name__ == "__main__":
    main()
