"""Expected GradCAM: Optimal gradient-weighted class activation maps.

This library implements Expected GradCAM, an XAI method that minimizes
explanation infidelity by computing optimal feature map weights.

Mathematical foundation:
    - Predictor: g(z'; A) = y^c(z'_1 * A^1, ..., z'_K * A^K)
    - Reference: z_0 = (1, ..., 1)
    - Infidelity: INFD(alpha) = E[(I^T alpha - (g(z_0) - g(z_0 - I)))^2]
    - Optimal weights: alpha* = M_I^{-1} * E[I * <I, phi>]
    - Heatmap: L^c = ReLU(sum_k alpha*_k * A^k)

Quick Start:
    >>> from expected_gradcam import ExpectedGradCAM, ExpectedGradCAMConfig
    >>>
    >>> # Create Expected GradCAM instance
    >>> config = ExpectedGradCAMConfig(M=50, N=20, T=50)
    >>> egcam = ExpectedGradCAM(model, target_layer, config=config)
    >>>
    >>> # Generate heatmap
    >>> result = egcam(image, class_idx=243)
    >>> heatmap = result.heatmap
"""

from __future__ import annotations

from expected_gradcam._version import __version__

# Configuration
from expected_gradcam.config import (
    DEFAULT_CONFIG,
    FAST_CONFIG,
    RESEARCH_CONFIG,
    ExpectedGradCAMConfig,
    GPUConfig,
)

# Type definitions
from expected_gradcam.types import (
    SolverMethod,
    WeightTransform,
)
from expected_gradcam.types.results import (
    ExpectedGradCAMResult,
    SolverDiagnostics,
)

# Exceptions
from expected_gradcam.exceptions import (
    ClassifierHeadExtractionError,
    DeviceMismatchError,
    ExpectedGradCAMError,
    GradientComputationError,
    InvalidInputShapeError,
    NumericalInstabilityError,
    SingularMatrixError,
    UnsupportedArchitectureError,
)

__all__ = [
    # Version
    "__version__",
    # Main API
    "ExpectedGradCAM",
    # Configuration
    "ExpectedGradCAMConfig",
    "GPUConfig",
    "DEFAULT_CONFIG",
    "FAST_CONFIG",
    "RESEARCH_CONFIG",
    # Types
    "SolverMethod",
    "WeightTransform",
    # Results
    "ExpectedGradCAMResult",
    "SolverDiagnostics",
    # Exceptions
    "ExpectedGradCAMError",
    "UnsupportedArchitectureError",
    "ClassifierHeadExtractionError",
    "SingularMatrixError",
    "NumericalInstabilityError",
    "GradientComputationError",
    "InvalidInputShapeError",
    "DeviceMismatchError",
]


def __getattr__(name: str):
    """Lazy loading for heavy modules."""
    if name == "ExpectedGradCAM":
        from expected_gradcam.api import ExpectedGradCAM

        return ExpectedGradCAM
    raise AttributeError(f"module {__name__!r} has no attribute {name!r}")
