"""
Reduction Module

Implements factor graph reductions via poset deformation retractions,
following Sergeant-Perthuis & Boitel's theory.

Two implementations:
1. graph_reduction.py - Original elimination-style reducer (kept for reference)
2. poset_reduction.py - Strict SP-B faithful implementation using incidence posets

Key concepts:
- Linear point: Variable with exactly ONE factor above it (leaf variable)
- Colinear point: Factor with exactly ONE variable below it (unary factor)
- Reductions proceed "outside-in" from leaves
- Intermediate objects may not be standard factor graphs
"""

# Original elimination-style reducer (kept for backwards compatibility)
from .graph_reduction import (
    FactorGraphReducer,
    ReductionStep as GraphReductionStep,
    ReductionResult,
    reduce_factor_graph,
)

# Strict SP-B faithful reducer
from .poset_reduction import (
    Region,
    PosetModel,
    ReductionStep,
    retract_linear,
    retract_colinear,
    reduce_to_core_spb,
    from_factor_graph,
    to_factor_graph_if_possible,
    reconstruct_deleted_belief,
    validate_linear_deletion_is_delete_only,
)

__all__ = [
    # Original reducer
    'FactorGraphReducer',
    'GraphReductionStep',
    'ReductionResult',
    'reduce_factor_graph',
    # Strict SP-B reducer
    'Region',
    'PosetModel', 
    'ReductionStep',
    'retract_linear',
    'retract_colinear',
    'reduce_to_core_spb',
    'from_factor_graph',
    'to_factor_graph_if_possible',
    'reconstruct_deleted_belief',
    'validate_linear_deletion_is_delete_only',
]
