"""
Chemical Reaction Network (CRN) Module

Implements compilation of factor graphs to chemical reaction networks
following Napp & Adams (2013) "Message Passing Inference with Chemical
Reaction Networks".

Key concepts:
- Each message component S^{j→n}_k and P^{n→j}_k is a chemical species
- Each marginal belief P^n_k is a chemical species
- Reactions implement sum-product message passing
- At steady state, concentrations represent BP marginals

Three types of reactions:
1. Recycling reactions: Return probability mass to unassigned state
2. Sum message reactions: Factor-to-variable messages (Eq. 12)
3. Product message reactions: Variable-to-factor messages (Eq. 16)

CRN Reduction:
- Direct SP-B retractions on CRNs (without recompiling from factor graphs)
- Linear retraction: Delete species/reactions (no rate changes)
- Colinear retraction: Delete + update survivor reaction rates
"""

from .crn_compiler import (
    Species,
    Reaction,
    ChemicalReactionNetwork,
    CRNCompiler,
    compile_factor_graph_to_crn,
)

from .crn_simulator import (
    CRNSimulator,
    SimulationResult,
    simulate_crn,
)

from .crn_reduction import (
    CRNReductionStep,
    CRNReducer,
    reduce_crn_to_core,
    compare_crn_structures,
)

__all__ = [
    'Species',
    'Reaction', 
    'ChemicalReactionNetwork',
    'CRNCompiler',
    'compile_factor_graph_to_crn',
    'CRNSimulator',
    'SimulationResult',
    'simulate_crn',
    'CRNReductionStep',
    'CRNReducer',
    'reduce_crn_to_core',
    'compare_crn_structures',
]
