"""Hook management utilities for PyTorch.

This module provides utilities for registering and managing PyTorch hooks
on model layers. Hooks enable capturing intermediate activations and
gradients during forward and backward passes.

Example:
    >>> from expected_gradcam.hooks import HookManager, FeatureMapHook
    >>>
    >>> # Basic hook management
    >>> with HookManager() as hooks:
    ...     hooks.register_forward(model.layer4, "features")
    ...     output = model(x)
    ...     features = hooks.get_output("features")
    >>>
    >>> # GradCAM-style feature and gradient capture
    >>> with FeatureMapHook(model.layer4) as hook:
    ...     output = model(x)
    ...     output[0, target].backward()
    ...     features = hook.features
    ...     gradients = hook.gradients
"""

from __future__ import annotations

from expected_gradcam.hooks.manager import (
    CapturedActivation,
    FeatureMapHook,
    GradientHook,
    HookManager,
    HookState,
    MultiLayerHooks,
    capture_activations,
)

__all__ = [
    # Dataclasses
    "CapturedActivation",
    "HookState",
    # Managers
    "HookManager",
    "MultiLayerHooks",
    # Context managers
    "capture_activations",
    # Specialized hooks
    "GradientHook",
    "FeatureMapHook",
]
