import numpy as np


def least_squares_align(pred: np.ndarray, gt: np.ndarray, mask: np.ndarray) -> tuple[np.ndarray, float, float]:
    pred = pred.astype(np.float64)
    gt = gt.astype(np.float64)
    valid = mask & np.isfinite(pred) & np.isfinite(gt)

    if not np.any(valid):
        return pred, 1.0, 0.0

    p = pred[valid]
    g = gt[valid]
    n = float(p.size)

    sum_p = float(np.sum(p))
    sum_g = float(np.sum(g))
    sum_pp = float(np.sum(p * p))
    sum_pg = float(np.sum(p * g))

    denom = n * sum_pp - sum_p * sum_p
    if abs(denom) < 1e-12:
        return pred, 1.0, 0.0

    scale = (n * sum_pg - sum_p * sum_g) / denom
    shift = (sum_g - scale * sum_p) / n

    aligned = scale * pred + shift
    return aligned, float(scale), float(shift)
