"""Research probes for intermediate value collection.

This module provides infrastructure for collecting intermediate values
during Expected GradCAM computation. This is useful for:
- Debugging and understanding algorithm behavior
- Research experiments comparing different configurations
- Collecting data for analysis and visualization

Two probe modes are available:
- SyncProbe: Blocking writes for immediate storage
- AsyncProbe: Queue-based with background thread for minimal overhead

Example:
    >>> from expected_gradcam.probes import SyncProbe, NPZStorage
    >>> storage = NPZStorage("experiment_data/")
    >>> probe = SyncProbe(storage)
    >>>
    >>> # Use with ExpectedGradCAM
    >>> result = egcam.compute(image, class_idx, probe=probe)
    >>> probe.flush()  # Ensure all data is written
"""

from __future__ import annotations

from expected_gradcam.probes.async_probe import AsyncProbe
from expected_gradcam.probes.collector import IntermediateCollector
from expected_gradcam.probes.protocols import ProbeCallback
from expected_gradcam.probes.storage import HDF5Storage, NPZStorage, StorageBackend
from expected_gradcam.probes.sync_probe import SyncProbe

__all__ = [
    # Protocol
    "ProbeCallback",
    # Collector
    "IntermediateCollector",
    # Probes
    "SyncProbe",
    "AsyncProbe",
    # Storage
    "StorageBackend",
    "NPZStorage",
    "HDF5Storage",
]
