"""Utility modules for Expected GradCAM.

This module provides utility functions for caching, timing, validation,
and visualization. These utilities are designed to work seamlessly with
PyTorch tensors and GPU operations.

Submodules:
    decorators: Function decorators for caching, timing, and validation.
    visualization: Heatmap overlay and comparison utilities.

Example:
    >>> from expected_gradcam.utils import timed, cached, overlay_heatmap
    >>>
    >>> @timed(log=True)
    ... @cached(maxsize=100)
    ... def compute_heatmap(image):
    ...     return egcam.generate(image).heatmap
    >>>
    >>> overlay = overlay_heatmap(image, heatmap, alpha=0.5)
"""

from __future__ import annotations

# Decorators
from expected_gradcam.utils.decorators import (
    LRUCache,
    TensorSpec,
    TimingStats,
    cached,
    cached_method,
    gpu_sync,
    inference_mode,
    no_grad,
    require_grad,
    retry,
    timed,
    validate_input,
    validate_output,
)

# Visualization
from expected_gradcam.utils.visualization import (
    COLORMAPS,
    apply_colormap,
    create_comparison,
    create_grid,
    normalize_heatmap,
    numpy_to_pil,
    overlay_heatmap,
    overlay_heatmap_pil,
    pil_to_numpy,
    resize_heatmap,
    save_visualization,
    tensor_to_numpy,
)

__all__ = [
    # Timing
    "timed",
    "TimingStats",
    "gpu_sync",
    # Caching
    "cached",
    "cached_method",
    "LRUCache",
    # Validation
    "validate_input",
    "validate_output",
    "TensorSpec",
    # Gradient control
    "require_grad",
    "no_grad",
    "inference_mode",
    # Retry
    "retry",
    # Colormap
    "apply_colormap",
    "COLORMAPS",
    # Image conversion
    "tensor_to_numpy",
    "numpy_to_pil",
    "pil_to_numpy",
    # Overlay
    "overlay_heatmap",
    "overlay_heatmap_pil",
    # Comparison
    "create_comparison",
    "create_grid",
    # Save
    "save_visualization",
    # Processing
    "resize_heatmap",
    "normalize_heatmap",
]
