"""Utility metrics for summarising Monte-Carlo simulations."""

from __future__ import annotations

from typing import Dict, Sequence

import numpy as np


def interval_metrics(
    estimates: Sequence[float], variances: Sequence[float], true_value: float, z_score: float
) -> Dict[str, float]:
    est = np.asarray(estimates, dtype=float)
    var = np.asarray(variances, dtype=float)
    se = np.sqrt(np.maximum(var, 0.0))
    lower = est - z_score * se
    upper = est + z_score * se
    coverage = float(np.mean((true_value >= lower) & (true_value <= upper)))
    rmse = float(np.sqrt(np.mean((est - true_value) ** 2)))
    ci_len = float(np.mean(upper - lower))
    return {"rmse": rmse, "coverage": coverage, "CIlen": ci_len}

