import numpy as np


def split_by_distance(gt: np.ndarray, mask: np.ndarray, bin_edges: list[float]) -> list[np.ndarray]:
    gt = gt.astype(np.float64)
    valid = mask & np.isfinite(gt) & (gt > 0)
    masks = []
    for i in range(len(bin_edges) - 1):
        lo = bin_edges[i]
        hi = bin_edges[i + 1]
        masks.append(valid & (gt >= lo) & (gt < hi))
    return masks


def split_by_distance_bins(gt: np.ndarray, mask: np.ndarray, bins: list[tuple[float, float | None]]) -> list[np.ndarray]:
    gt = gt.astype(np.float64)
    valid = mask & np.isfinite(gt) & (gt > 0)
    masks = []
    for lo, hi in bins:
        upper = float("inf") if hi is None else hi
        masks.append(valid & (gt >= lo) & (gt < upper))
    return masks
