"""Core computation modules for Expected GradCAM.

This module provides the fundamental building blocks:
- Predictor: g(z; A) function evaluation
- Path Integration: Integrated/Expected Gradients
- Second Moment: M_I matrix computation
- Optimal Weights: Linear system solvers
- Weight Transform: Post-processing transforms
- Heatmap: Generation and processing
"""

from expected_gradcam.core.predictor import Predictor, BatchedPredictor
from expected_gradcam.core.path_integration import (
    IntegratedGradients,
    ExpectedGradients,
    compute_attribution,
)
from expected_gradcam.core.second_moment import (
    compute_second_moment_matrix,
    compute_cross_moment,
    analyze_second_moment_matrix,
    IncrementalMomentComputer,
)
from expected_gradcam.core.optimal_weights import (
    solve_linear_system,
    solve_linear_system_robust,
    compute_optimal_weights,
    verify_optimality,
    compute_infidelity,
)
from expected_gradcam.core.weight_transform import (
    transform_weights,
    double_power_transform,
    extreme_power_transform,
    feature_adaptive_transform,
    fixed_power_transform,
)
from expected_gradcam.core.heatmap import (
    generate_heatmap,
    upsample_heatmap,
    normalize_heatmap,
    apply_contrast_enhancement,
    process_heatmap,
)
from expected_gradcam.core.weight_computer import ExpectedGradCAMWeightComputer
from expected_gradcam.core.callbacks import (
    ChunkResult,
    IntermediateHeatmap,
    SolverProgress,
    ComputationObserver,
    NullComputationObserver,
    LoggingObserver,
    DataCollectorObserver,
)
from expected_gradcam.core.observer_manager import ObserverManager


__all__ = [
    # Predictor
    "Predictor",
    "BatchedPredictor",
    # Path Integration
    "IntegratedGradients",
    "ExpectedGradients",
    "compute_attribution",
    # Second Moment
    "compute_second_moment_matrix",
    "compute_cross_moment",
    "analyze_second_moment_matrix",
    "IncrementalMomentComputer",
    # Optimal Weights
    "solve_linear_system",
    "solve_linear_system_robust",
    "compute_optimal_weights",
    "verify_optimality",
    "compute_infidelity",
    # Weight Transform
    "transform_weights",
    "double_power_transform",
    "extreme_power_transform",
    "feature_adaptive_transform",
    "fixed_power_transform",
    # Heatmap
    "generate_heatmap",
    "upsample_heatmap",
    "normalize_heatmap",
    "apply_contrast_enhancement",
    "process_heatmap",
    # Weight Computer
    "ExpectedGradCAMWeightComputer",
    # Callbacks
    "ChunkResult",
    "IntermediateHeatmap",
    "SolverProgress",
    "ComputationObserver",
    "NullComputationObserver",
    "LoggingObserver",
    "DataCollectorObserver",
    "ObserverManager",
]
