import os

# Confine computational resources strictly to a single processing core
# This sidesteps systemic bottlenecks and unpredictable race conditions caused by library thread pooling natively locking I/O boundaries
os.environ["OMP_NUM_THREADS"] = "1"
os.environ["OPENBLAS_NUM_THREADS"] = "1"
os.environ["MKL_NUM_THREADS"] = "1"
os.environ["VECLIB_MAXIMUM_THREADS"] = "1"
os.environ["NUMEXPR_NUM_THREADS"] = "1"

import argparse
from pathlib import Path
import sys
import numpy as np
import cv2

cv2.setNumThreads(0)

SCRIPT_DIR = Path(__file__).resolve().parent
sys.path.append(str(SCRIPT_DIR))

from core.alignment import least_squares_align
from core.convert import inverse_to_depth
from core.evaluator import apply_max_depth_mask
from core.io import read_pfm, load_depth_npy, resize_to_match
from core.multiprocessing_utils import default_worker_count, run_process_pool_as_completed

ROOT_DEFAULT = "path/to/lusnar-dataset"
MAX_DEPTH = 50.0

# 65500 explicitly encodes physical sky bounds in LuSNAR architecture natively voiding distance
SKY_SENTINEL = 65500.0

_OPENCV_CMAPS = {
    "viridis": cv2.COLORMAP_VIRIDIS,
    "magma":   cv2.COLORMAP_MAGMA,
    "inferno": cv2.COLORMAP_INFERNO,
    "plasma":  cv2.COLORMAP_PLASMA,
    "jet":     cv2.COLORMAP_JET,
    "turbo":   cv2.COLORMAP_TURBO,
}

def _valid_gt_mask(gt: np.ndarray) -> np.ndarray:
    """
    Constructs an explicit spatial boundary matrix restricting computational outputs exclusively against validated metrics.
    Bounds exclude explicit zeroes (missing paths) and Sentinel markers natively indicating out-of-bounds topological sky elements.
    """
    return np.isfinite(gt) & (gt > 0) & (gt < SKY_SENTINEL)

def _normalize_depth(
    depth: np.ndarray,
    mask: np.ndarray,
    p_low: float = 1.0,
    p_high: float = 99.0,
) -> tuple[np.ndarray, np.ndarray]:
    """
    Normalizes complex absolute matrices directly to bounds organically limiting output distribution values seamlessly.
    Truncating specific extreme values explicitly preserves local spatial depth progressions avoiding washout over expansive horizons natively.
    """
    depth = depth.astype(np.float64)
    valid = np.isfinite(depth) & mask

    if not np.any(valid):
        return np.zeros_like(depth, dtype=np.float64), valid

    # Interpolate statistical ceilings specifically limiting arbitrary boundary noise naturally occurring within simulation structures 
    vals = depth[valid]
    lo = float(np.percentile(vals, p_low))
    hi = float(np.percentile(vals, p_high))

    if not np.isfinite(lo) or not np.isfinite(hi) or hi <= lo:
        return np.zeros_like(depth, dtype=np.float64), valid

    clipped = np.clip(depth, lo, hi)
    norm = np.zeros_like(depth, dtype=np.float64)
    
    # Render limits dynamically directly into proportional scaling arrays naturally compatible with standard integer mappings
    norm[valid] = (clipped[valid] - lo) / (hi - lo)

    valid_after = valid & np.isfinite(norm)
    return np.clip(norm, 0.0, 1.0), valid_after

def _save_visualization(
    depth: np.ndarray,
    mask: np.ndarray,
    out_path: Path,
    cmap_name: str,
    p_low: float,
    p_high: float
) -> None:
    """
    Transcodes raw float distributions structurally into explicit visualization domains converting logical depth natively into RGB intensity channels.
    Applying mapping explicitly over invalid frames preserves true structural evaluation geometries perfectly avoiding graphical hallucination.
    """
    out_path.parent.mkdir(parents=True, exist_ok=True)

    norm_depth, valid_mask = _normalize_depth(depth, mask, p_low, p_high)

    # Shift domain arrays precisely transforming raw matrices natively mapped toward 8-bit space constraints 
    out_8bit = np.zeros_like(norm_depth, dtype=np.uint8)
    out_8bit[valid_mask] = (norm_depth[valid_mask] * 255).astype(np.uint8)

    cmap_code = _OPENCV_CMAPS.get(cmap_name, cv2.COLORMAP_INFERNO)
    colored = cv2.applyColorMap(out_8bit, cmap_code)
    
    # Enforce pure masking rendering void spaces black unambiguously preventing arbitrary colorization of infinite metric skies  
    colored[~valid_mask] = [0, 0, 0]
    
    cv2.imwrite(str(out_path), colored)

def _pred_candidates_for_sequence(pred_seq_dir: Path) -> list[Path]:
    """
    Recursively audits structural layouts intelligently identifying specific inference directories 
    navigating through inconsistent subfolder outputs typically generated during iterative evaluation script execution natively.
    """
    root_files = sorted(pred_seq_dir.glob("*.npy"))
    if root_files:
        return root_files
    depth_npy_files = sorted((pred_seq_dir / "depth_npy").glob("*.npy"))
    if depth_npy_files:
        return depth_npy_files
    return sorted((pred_seq_dir / "depth").glob("*.npy"))

def _collect_sequence_pairs(root: Path, pred_root: Path) -> list[tuple[Path, Path]]:
    """
    Correlates prediction arrays dynamically matching original environmental sequences intelligently across fragmented subfolders cleanly.
    LuSNAR implements sequenced Moon limits natively iterating 1 through 9.
    """
    pairs = []
    # Explicit loop tracking sequence naming syntaxes uniformly iterating through Moon sub-targets
    for seq in range(1, 10):
        seq_name = f"Moon_{seq}"
        gt_dir = root / seq_name / "image0" / "depth"
        pred_dir = pred_root / seq_name

        if not gt_dir.exists() or not pred_dir.exists():
            continue

        # Standard file format differences handled natively resolving PFM source files effectively against standard prediction maps
        gt_files = sorted(gt_dir.glob("*.pfm"))
        pred_files = _pred_candidates_for_sequence(pred_dir)
        
        pred_map = {p.stem: p for p in pred_files}

        for gt_path in gt_files:
            stem = gt_path.stem
            pred_path = pred_map.get(stem)
            
            if pred_path:
                pairs.append((gt_path, pred_path))
            
    return pairs

def _process_single_pair(task: tuple) -> None:
    """
    Consumes independent output matrices structurally normalizing logical limits exactly as the system evaluator implements them internally.
    Alignments process identically matching explicit quantitative masking logic strictly eliminating visual contradictions perfectly.
    """
    (gt_path_str, pred_path_str, take_inverse, eps,
     max_depth, output_dir_str, cmap, p_low, p_high) = task

    gt_path = Path(gt_path_str)
    pred_path = Path(pred_path_str)
    output_dir = Path(output_dir_str)

    # Decode PFM inputs natively loading unique single-precision structures 
    gt = read_pfm(str(gt_path))
    pred = load_depth_npy(str(pred_path))
    
    # Homogenize structural outputs uniformly padding ambiguous prediction padding limits to physical metric scales natively 
    pred = resize_to_match(pred, gt)

    if take_inverse:
        pred_depth, pred_valid = inverse_to_depth(pred, eps=eps)
    else:
        pred_depth = pred.astype(np.float64)
        pred_valid = np.isfinite(pred_depth)

    # Establish bounds natively extracting valid analytical geometries completely rejecting obscure metric horizons identically to evaluators
    base_mask = _valid_gt_mask(gt) & pred_valid
    base_mask = apply_max_depth_mask(gt, base_mask, max_depth)

    # Conform limits scaling dynamically solving global scale constraints logically prior to visual mapping
    aligned_pred, scale, shift = least_squares_align(pred_depth, gt, base_mask)

    seq_name = gt_path.parents[2].name
    out_file = output_dir / seq_name / f"{pred_path.stem}.png"

    _save_visualization(aligned_pred, base_mask, out_file, cmap_name=cmap, p_low=p_low, p_high=p_high)


def main() -> None:
    ap = argparse.ArgumentParser(description="Visualize LuSNAR predictions translating structures faithfully recreating exact quantitative processing boundaries dynamically.")
    ap.add_argument("--pred-dir", required=True)
    ap.add_argument("--output-dir", required=True)
    ap.add_argument("--root", default=ROOT_DEFAULT)
    ap.add_argument("--take-inverse", action="store_true")
    ap.add_argument("--cmap", default="inferno", choices=_OPENCV_CMAPS.keys())
    ap.add_argument("--p-low", type=float, default=1.0)
    ap.add_argument("--p-high", type=float, default=99.0)
    ap.add_argument("--max-depth", type=float, default=MAX_DEPTH)
    ap.add_argument("--eps", type=float, default=1e-6)
    ap.add_argument("--workers", type=int, default=default_worker_count())

    args = ap.parse_args()

    root = Path(args.root)
    pred_root = Path(args.pred_dir)
    output_dir = Path(args.output_dir)

    print(f"Collecting pairs from {pred_root}...")
    pairs = _collect_sequence_pairs(root, pred_root)
    if not pairs:
        raise SystemExit("No matching GT/Prediction pairs found.")

    print(f"Found {len(pairs)} pairs. Processing...")

    tasks = [
        (str(gt_path), str(pred_path), args.take_inverse, args.eps,
         args.max_depth, str(output_dir), args.cmap, args.p_low, args.p_high)
        for gt_path, pred_path in pairs
    ]

    workers = max(1, int(args.workers))

    # Control diagnostic noise natively returning clear iterative metrics
    def _on_progress(completed: int, total: int) -> None:
        if completed % 100 == 0 or completed == total:
            print(f"Processed {completed}/{total}")

    run_process_pool_as_completed(_process_single_pair, tasks, workers=workers, progress_callback=_on_progress)
    print(f"Done. Visualizations saved to {output_dir}")

if __name__ == "__main__":
    main()