"""
Configuration for the microBlooM vascular hex-network benchmark.

Loads edge-level parameters from
    experiments/vascular_hex/vascular_hex_graph.npz
and exposes a `config` dict compatible with `main.adapter`.
"""

from __future__ import annotations

from pathlib import Path

import numpy as np
from sorcerun.git_utils import (
    is_dirty,
    get_repo,
    get_commit_hash,
    get_time_str,
    get_tree_hash,
)
from config import _compute_stability_limit

repo = get_repo()
REPO_ROOT = Path(repo.working_dir)

GRAPH_PATH = REPO_ROOT / "experiments" / "vascular_hex" / "vascular_hex_graph.npz"

if not GRAPH_PATH.exists():
    raise FileNotFoundError(
        f"Missing vascular graph file at {GRAPH_PATH}. "
        "Run the converter before launching the experiment."
    )

T = 0.15
num_particles = int(5e4)
num_bins = 200
sigma = 1.0
make_gif = False
error_norm = 2
run_fvm = False

data = np.load(GRAPH_PATH)
num_edges = int(data["num_edges"])
edge_lengths = data["edge_lengths"].astype(np.float64).tolist()
drift_coeffs = data["drift_coeffs"].astype(np.float64).tolist()
edge_vertices = data["edge_vertices"].astype(np.int32).tolist()
vertex_edge_offsets = data["vertex_edge_offsets"].astype(np.int32).tolist()
vertex_edge_indices = data["vertex_edge_indices"].astype(np.int32).tolist()
vertex_edge_orientations = data["vertex_edge_orientations"].astype(np.int32).tolist()
vertex_edge_cumweights = data["vertex_edge_cumweights"].astype(np.float64).tolist()
jump_weights = (np.ones(num_edges, dtype=np.float64) / num_edges).tolist()

assert len(edge_lengths) == num_edges
assert len(drift_coeffs) == num_edges
assert len(edge_vertices) == num_edges

dx = float(edge_lengths[0]) / num_bins
d_max = _compute_stability_limit(
    drift_coeffs,
    D=sigma**2 / 2,
    dx=dx,
)
dt = min(1e-5, d_max / 2)
steps = int(T / dt)

config = {
    "num_particles": num_particles,
    "num_bins": num_bins,
    "steps": steps,
    "dt": dt,
    "sigma": sigma,
    "num_edges": num_edges,
    "edge_lengths": edge_lengths,
    "drift_coeffs": drift_coeffs,
    "potential_type": "quadratic",
    "jump_weights": jump_weights,
    "edge_vertices": edge_vertices,
    "vertex_edge_offsets": vertex_edge_offsets,
    "vertex_edge_indices": vertex_edge_indices,
    "vertex_edge_orientations": vertex_edge_orientations,
    "vertex_edge_cumweights": vertex_edge_cumweights,
    "make_gif": make_gif,
    "error_norm": error_norm,
    "run_fvm": run_fvm,
    "backend": "cuda",
    "commit_hash": get_commit_hash(repo),
    "main_tree_hash": get_tree_hash(repo, "main"),
    "time_str": get_time_str(),
    "dirty": is_dirty(get_repo()),
}
