from pathlib import Path
import cv2
import numpy as np


def list_sorted_files(directory: str, exts: tuple[str, ...]) -> list[Path]:
    root = Path(directory)
    files: list[Path] = []
    for ext in exts:
        files.extend(sorted(root.glob(f"*{ext}")))
    return sorted(files)


def load_depth_png(path: str) -> np.ndarray:
    img = cv2.imread(path, cv2.IMREAD_UNCHANGED)
    if img is None:
        raise FileNotFoundError(f"Could not load depth PNG: {path}")
    if img.ndim == 3:
        img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    return img.astype(np.float32)


def load_depth_npy(path: str) -> np.ndarray:
    data = np.load(path)
    return data.astype(np.float32)


def resize_to_match(pred: np.ndarray, gt: np.ndarray) -> np.ndarray:
    if pred.shape == gt.shape:
        return pred
    return cv2.resize(pred, (gt.shape[1], gt.shape[0]), interpolation=cv2.INTER_LINEAR)


def load_rgb_image(path: str) -> np.ndarray:
    img = cv2.imread(path, cv2.IMREAD_COLOR)
    if img is None:
        raise FileNotFoundError(f"Could not load RGB image: {path}")
    return img


def read_pfm(path: str) -> np.ndarray:
    with open(path, "rb") as f:
        header = f.readline().decode("ascii", errors="ignore").strip()
        if header not in {"PF", "Pf"}:
            raise ValueError(f"Not a PFM file: {path}")
        color = header == "PF"

        dims = f.readline().decode("ascii", errors="ignore").strip()
        while dims.startswith("#") or dims == "":
            dims = f.readline().decode("ascii", errors="ignore").strip()
        try:
            width, height = map(int, dims.split())
        except ValueError as e:
            raise ValueError(f"Invalid PFM dimensions in {path}") from e

        scale_line = f.readline().decode("ascii", errors="ignore").strip()
        try:
            scale = float(scale_line)
        except ValueError as e:
            raise ValueError(f"Invalid PFM scale in {path}") from e

        endian = "<" if scale < 0 else ">"
        scale = abs(scale)

        count = width * height * (3 if color else 1)
        data = np.fromfile(f, endian + "f", count=count)
        if data.size != count:
            raise ValueError(f"Unexpected PFM data size in {path}")

        if color:
            data = data.reshape((height, width, 3))
        else:
            data = data.reshape((height, width))

        if scale != 1.0:
            data = data * scale
        return data.astype(np.float32)
