from __future__ import annotations

from typing import List, Tuple

import numpy as np


def default_lam(d: int, effective_n: float, lam_scale: float = 1.0) -> float:
    """Compute the default L1 penalty scaling."""
    return lam_scale * np.sqrt(np.log(d + 1.0) / max(effective_n, 1.0))


def mean_ci(values: List[float], z: float = 1.96) -> Tuple[float, float, float, float]:
    """Compute mean, confidence interval, and median."""
    v = np.asarray(values, dtype=float)
    if v.size == 0:
        return np.nan, np.nan, np.nan, np.nan
    mu = float(v.mean())
    med = float(np.median(v))
    if v.size == 1:
        return mu, mu, mu, med
    sd = float(v.std(ddof=1))
    hw = z * sd / np.sqrt(v.size)
    return mu, mu - hw, mu + hw, med
