"""
Solvers module for MMSBVI
MMSBVI求解器模块

This module provides PDE solvers and related numerical methods.
本模块提供PDE求解器和相关数值方法。
"""

from .pde_solver_1d import (
    solve_onsager_fokker_pde,
    compute_onsager_fokker_metric,
    validate_pde_solution,
    create_test_problem_1d,
    operator_adjointness_error,
    # backward-compatible aliases
    solve_onsager_fokker_pde_fixed,
    compute_onsager_fokker_metric_fixed,
    validate_pde_solution_fixed,
    create_test_problem_1d_fixed,
)

from .gaussian_kernel_1d import (
    apply_ou_kernel_1d,
    apply_backward_ou_kernel_1d,
    compute_log_transition_kernel_1d,
    estimate_kernel_bandwidth,
    validate_ou_kernel_properties,
    compare_with_analytical_ou,
    # backward-compatible aliases
    apply_ou_kernel_1d_fixed,
    apply_backward_ou_kernel_1d_fixed,
    compute_log_transition_kernel_1d_fixed,
    estimate_kernel_bandwidth_fixed,
)

from .gaussian_kernel_2d import (
    apply_ou_kernel_2d_separable,
    apply_ou_kernel_2d_separable_fixed,
    compute_log_transition_kernels_2d_separable,
    compute_log_transition_kernels_2d_separable_fixed,
    estimate_kernel_bandwidth_2d,
    estimate_kernel_bandwidth_2d_fixed,
    validate_ou_kernel_properties_2d,
)

__all__ = [
    # PDE solver
    "solve_onsager_fokker_pde",
    "compute_onsager_fokker_metric", 
    "validate_pde_solution",
    "create_test_problem_1d",
    "operator_adjointness_error",
    # OU kernel
    "apply_ou_kernel_1d",
    "apply_backward_ou_kernel_1d",
    "compute_log_transition_kernel_1d",
    "estimate_kernel_bandwidth",
    "validate_ou_kernel_properties",
    "compare_with_analytical_ou",
    # 2D OU kernel
    "apply_ou_kernel_2d_separable",
    "compute_log_transition_kernels_2d_separable",
    "estimate_kernel_bandwidth_2d",
    "validate_ou_kernel_properties_2d",
    # Backward-compatible names (exported for tests)
    "solve_onsager_fokker_pde_fixed",
    "compute_onsager_fokker_metric_fixed", 
    "validate_pde_solution_fixed",
    "create_test_problem_1d_fixed",
    "apply_ou_kernel_1d_fixed",
    "apply_backward_ou_kernel_1d_fixed",
    "compute_log_transition_kernel_1d_fixed",
    "estimate_kernel_bandwidth_fixed",
    "apply_ou_kernel_2d_separable_fixed",
    "compute_log_transition_kernels_2d_separable_fixed",
    "estimate_kernel_bandwidth_2d_fixed",
]