"""Infidelity metrics for Expected GradCAM.

This package provides infidelity metrics that measure how well the
linear approximation (I^T α) predicts actual model output changes.

Two implementations are available:
- `InternalInfidelity`: Feature-space infidelity (zero additional cost)
- `BatchedInfidelity`: Input-space infidelity with GPU batching

The internal (feature-space) infidelity is preferred because:
1. It uses values already computed during E-GradCAM
2. No additional forward passes required
3. Directly measures the quality of the linear approximation

Example:
    >>> from expected_gradcam.metrics.infidelity import InternalInfidelity
    >>>
    >>> metric = InternalInfidelity()
    >>> infidelity = metric.compute(
    ...     alpha=alpha,           # [K] optimal weights
    ...     I_samples=I_samples,   # [M, K] feature-space perturbations
    ...     g_z0=g_z0,             # scalar reference output
    ...     g_perturbed=g_perturbed,  # [M] perturbed outputs
    ... )
"""

from expected_gradcam.metrics.infidelity.internal import InternalInfidelity

__all__ = [
    "InternalInfidelity",
]

# Lazy import for BatchedInfidelity to avoid heavy dependencies
def __getattr__(name: str):  # noqa: ANN202
    if name == "BatchedInfidelity":
        from expected_gradcam.metrics.infidelity.batched import BatchedInfidelity
        return BatchedInfidelity
    raise AttributeError(f"module {__name__!r} has no attribute {name!r}")
