boost.cxx 0.0.2 → 1.90.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -2
- package/boost/cast.hpp +20 -0
- package/boost/numeric/conversion/bounds.hpp +24 -0
- package/boost/numeric/conversion/cast.hpp +61 -0
- package/boost/numeric/conversion/conversion_traits.hpp +32 -0
- package/boost/numeric/conversion/converter.hpp +68 -0
- package/boost/numeric/conversion/converter_policies.hpp +194 -0
- package/boost/numeric/conversion/detail/bounds.hpp +58 -0
- package/boost/numeric/conversion/detail/conversion_traits.hpp +97 -0
- package/boost/numeric/conversion/detail/converter.hpp +593 -0
- package/boost/numeric/conversion/detail/int_float_mixture.hpp +72 -0
- package/boost/numeric/conversion/detail/is_subranged.hpp +234 -0
- package/boost/numeric/conversion/detail/meta.hpp +120 -0
- package/boost/numeric/conversion/detail/numeric_cast_traits.hpp +138 -0
- package/boost/numeric/conversion/detail/old_numeric_cast.hpp +308 -0
- package/boost/numeric/conversion/detail/preprocessed/numeric_cast_traits_common.hpp +1741 -0
- package/boost/numeric/conversion/detail/preprocessed/numeric_cast_traits_long_long.hpp +347 -0
- package/boost/numeric/conversion/detail/sign_mixture.hpp +72 -0
- package/boost/numeric/conversion/detail/udt_builtin_mixture.hpp +69 -0
- package/boost/numeric/conversion/int_float_mixture.hpp +30 -0
- package/boost/numeric/conversion/int_float_mixture_enum.hpp +29 -0
- package/boost/numeric/conversion/is_subranged.hpp +27 -0
- package/boost/numeric/conversion/numeric_cast_traits.hpp +31 -0
- package/boost/numeric/conversion/sign_mixture.hpp +30 -0
- package/boost/numeric/conversion/sign_mixture_enum.hpp +29 -0
- package/boost/numeric/conversion/udt_builtin_mixture.hpp +28 -0
- package/boost/numeric/conversion/udt_builtin_mixture_enum.hpp +26 -0
- package/boost/numeric/interval/arith.hpp +305 -0
- package/boost/numeric/interval/arith2.hpp +304 -0
- package/boost/numeric/interval/arith3.hpp +69 -0
- package/boost/numeric/interval/checking.hpp +130 -0
- package/boost/numeric/interval/compare/certain.hpp +113 -0
- package/boost/numeric/interval/compare/explicit.hpp +248 -0
- package/boost/numeric/interval/compare/lexicographic.hpp +122 -0
- package/boost/numeric/interval/compare/possible.hpp +113 -0
- package/boost/numeric/interval/compare/set.hpp +101 -0
- package/boost/numeric/interval/compare/tribool.hpp +138 -0
- package/boost/numeric/interval/compare.hpp +19 -0
- package/boost/numeric/interval/constants.hpp +85 -0
- package/boost/numeric/interval/detail/alpha_rounding_control.hpp +113 -0
- package/boost/numeric/interval/detail/bcc_rounding_control.hpp +57 -0
- package/boost/numeric/interval/detail/bugs.hpp +48 -0
- package/boost/numeric/interval/detail/c99_rounding_control.hpp +50 -0
- package/boost/numeric/interval/detail/c99sub_rounding_control.hpp +43 -0
- package/boost/numeric/interval/detail/division.hpp +194 -0
- package/boost/numeric/interval/detail/ia64_rounding_control.hpp +83 -0
- package/boost/numeric/interval/detail/interval_prototype.hpp +41 -0
- package/boost/numeric/interval/detail/msvc_rounding_control.hpp +113 -0
- package/boost/numeric/interval/detail/ppc_rounding_control.hpp +99 -0
- package/boost/numeric/interval/detail/sparc_rounding_control.hpp +112 -0
- package/boost/numeric/interval/detail/test_input.hpp +76 -0
- package/boost/numeric/interval/detail/x86_rounding_control.hpp +108 -0
- package/boost/numeric/interval/detail/x86gcc_rounding_control.hpp +51 -0
- package/boost/numeric/interval/ext/integer.hpp +70 -0
- package/boost/numeric/interval/ext/x86_fast_rounding_control.hpp +70 -0
- package/boost/numeric/interval/hw_rounding.hpp +73 -0
- package/boost/numeric/interval/interval.hpp +450 -0
- package/boost/numeric/interval/io.hpp +41 -0
- package/boost/numeric/interval/limits.hpp +49 -0
- package/boost/numeric/interval/policies.hpp +75 -0
- package/boost/numeric/interval/rounded_arith.hpp +120 -0
- package/boost/numeric/interval/rounded_transc.hpp +140 -0
- package/boost/numeric/interval/rounding.hpp +101 -0
- package/boost/numeric/interval/transc.hpp +232 -0
- package/boost/numeric/interval/utility.hpp +335 -0
- package/boost/numeric/interval/utility_fwd.hpp +172 -0
- package/boost/numeric/interval.hpp +32 -0
- package/boost/numeric/odeint/algebra/algebra_dispatcher.hpp +86 -0
- package/boost/numeric/odeint/algebra/array_algebra.hpp +293 -0
- package/boost/numeric/odeint/algebra/default_operations.hpp +599 -0
- package/boost/numeric/odeint/algebra/detail/extract_value_type.hpp +51 -0
- package/boost/numeric/odeint/algebra/detail/for_each.hpp +165 -0
- package/boost/numeric/odeint/algebra/detail/macros.hpp +35 -0
- package/boost/numeric/odeint/algebra/detail/norm_inf.hpp +46 -0
- package/boost/numeric/odeint/algebra/fusion_algebra.hpp +216 -0
- package/boost/numeric/odeint/algebra/fusion_algebra_dispatcher.hpp +48 -0
- package/boost/numeric/odeint/algebra/multi_array_algebra.hpp +146 -0
- package/boost/numeric/odeint/algebra/norm_result_type.hpp +33 -0
- package/boost/numeric/odeint/algebra/operations_dispatcher.hpp +41 -0
- package/boost/numeric/odeint/algebra/range_algebra.hpp +142 -0
- package/boost/numeric/odeint/algebra/vector_space_algebra.hpp +175 -0
- package/boost/numeric/odeint/config.hpp +53 -0
- package/boost/numeric/odeint/external/blaze/blaze_algebra_dispatcher.hpp +55 -0
- package/boost/numeric/odeint/external/blaze/blaze_resize.hpp +64 -0
- package/boost/numeric/odeint/external/compute/compute.hpp +27 -0
- package/boost/numeric/odeint/external/compute/compute_algebra.hpp +65 -0
- package/boost/numeric/odeint/external/compute/compute_algebra_dispatcher.hpp +41 -0
- package/boost/numeric/odeint/external/compute/compute_operations.hpp +198 -0
- package/boost/numeric/odeint/external/compute/compute_operations_dispatcher.hpp +44 -0
- package/boost/numeric/odeint/external/compute/compute_resize.hpp +92 -0
- package/boost/numeric/odeint/external/eigen/eigen.hpp +27 -0
- package/boost/numeric/odeint/external/eigen/eigen_algebra.hpp +98 -0
- package/boost/numeric/odeint/external/eigen/eigen_algebra_dispatcher.hpp +49 -0
- package/boost/numeric/odeint/external/eigen/eigen_resize.hpp +103 -0
- package/boost/numeric/odeint/external/gsl/gsl_wrapper.hpp +228 -0
- package/boost/numeric/odeint/external/mkl/mkl_operations.hpp +181 -0
- package/boost/numeric/odeint/external/mpi/mpi.hpp +25 -0
- package/boost/numeric/odeint/external/mpi/mpi_nested_algebra.hpp +62 -0
- package/boost/numeric/odeint/external/mpi/mpi_state.hpp +113 -0
- package/boost/numeric/odeint/external/mpi/mpi_vector_state.hpp +95 -0
- package/boost/numeric/odeint/external/mtl4/implicit_euler_mtl4.hpp +161 -0
- package/boost/numeric/odeint/external/mtl4/mtl4.hpp +23 -0
- package/boost/numeric/odeint/external/mtl4/mtl4_algebra_dispatcher.hpp +99 -0
- package/boost/numeric/odeint/external/mtl4/mtl4_resize.hpp +134 -0
- package/boost/numeric/odeint/external/nt2/nt2_algebra_dispatcher.hpp +25 -0
- package/boost/numeric/odeint/external/nt2/nt2_copy.hpp +33 -0
- package/boost/numeric/odeint/external/nt2/nt2_norm_inf.hpp +31 -0
- package/boost/numeric/odeint/external/nt2/nt2_resize.hpp +54 -0
- package/boost/numeric/odeint/external/openmp/openmp.hpp +31 -0
- package/boost/numeric/odeint/external/openmp/openmp_nested_algebra.hpp +281 -0
- package/boost/numeric/odeint/external/openmp/openmp_range_algebra.hpp +276 -0
- package/boost/numeric/odeint/external/openmp/openmp_state.hpp +172 -0
- package/boost/numeric/odeint/external/thrust/thrust.hpp +27 -0
- package/boost/numeric/odeint/external/thrust/thrust_algebra.hpp +217 -0
- package/boost/numeric/odeint/external/thrust/thrust_algebra_dispatcher.hpp +118 -0
- package/boost/numeric/odeint/external/thrust/thrust_operations.hpp +233 -0
- package/boost/numeric/odeint/external/thrust/thrust_operations_dispatcher.hpp +118 -0
- package/boost/numeric/odeint/external/thrust/thrust_resize.hpp +197 -0
- package/boost/numeric/odeint/external/vexcl/vexcl.hpp +28 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_abs.hpp +61 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_algebra_dispatcher.hpp +51 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_copy.hpp +55 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_norm_inf.hpp +68 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_resize.hpp +96 -0
- package/boost/numeric/odeint/external/vexcl/vexcl_same_instance.hpp +58 -0
- package/boost/numeric/odeint/external/viennacl/viennacl_operations.hpp +226 -0
- package/boost/numeric/odeint/external/viennacl/viennacl_resize.hpp +68 -0
- package/boost/numeric/odeint/integrate/check_adapter.hpp +222 -0
- package/boost/numeric/odeint/integrate/detail/functors.hpp +70 -0
- package/boost/numeric/odeint/integrate/detail/integrate_adaptive.hpp +161 -0
- package/boost/numeric/odeint/integrate/detail/integrate_const.hpp +167 -0
- package/boost/numeric/odeint/integrate/detail/integrate_n_steps.hpp +161 -0
- package/boost/numeric/odeint/integrate/detail/integrate_times.hpp +179 -0
- package/boost/numeric/odeint/integrate/integrate.hpp +133 -0
- package/boost/numeric/odeint/integrate/integrate_adaptive.hpp +127 -0
- package/boost/numeric/odeint/integrate/integrate_const.hpp +195 -0
- package/boost/numeric/odeint/integrate/integrate_n_steps.hpp +178 -0
- package/boost/numeric/odeint/integrate/integrate_times.hpp +220 -0
- package/boost/numeric/odeint/integrate/max_step_checker.hpp +114 -0
- package/boost/numeric/odeint/integrate/null_observer.hpp +38 -0
- package/boost/numeric/odeint/integrate/observer_collection.hpp +55 -0
- package/boost/numeric/odeint/iterator/adaptive_iterator.hpp +183 -0
- package/boost/numeric/odeint/iterator/adaptive_time_iterator.hpp +175 -0
- package/boost/numeric/odeint/iterator/const_step_iterator.hpp +180 -0
- package/boost/numeric/odeint/iterator/const_step_time_iterator.hpp +173 -0
- package/boost/numeric/odeint/iterator/detail/ode_iterator_base.hpp +199 -0
- package/boost/numeric/odeint/iterator/impl/adaptive_iterator_impl.hpp +251 -0
- package/boost/numeric/odeint/iterator/impl/const_step_iterator_impl.hpp +228 -0
- package/boost/numeric/odeint/iterator/impl/n_step_iterator_impl.hpp +239 -0
- package/boost/numeric/odeint/iterator/impl/times_iterator_impl.hpp +369 -0
- package/boost/numeric/odeint/iterator/integrate/detail/functors.hpp +70 -0
- package/boost/numeric/odeint/iterator/integrate/detail/integrate_adaptive.hpp +121 -0
- package/boost/numeric/odeint/iterator/integrate/detail/integrate_const.hpp +111 -0
- package/boost/numeric/odeint/iterator/integrate/detail/integrate_n_steps.hpp +107 -0
- package/boost/numeric/odeint/iterator/integrate/detail/integrate_times.hpp +67 -0
- package/boost/numeric/odeint/iterator/integrate/integrate.hpp +111 -0
- package/boost/numeric/odeint/iterator/integrate/integrate_adaptive.hpp +127 -0
- package/boost/numeric/odeint/iterator/integrate/integrate_const.hpp +158 -0
- package/boost/numeric/odeint/iterator/integrate/integrate_n_steps.hpp +123 -0
- package/boost/numeric/odeint/iterator/integrate/integrate_times.hpp +131 -0
- package/boost/numeric/odeint/iterator/integrate/null_observer.hpp +38 -0
- package/boost/numeric/odeint/iterator/integrate/observer_collection.hpp +55 -0
- package/boost/numeric/odeint/iterator/n_step_iterator.hpp +168 -0
- package/boost/numeric/odeint/iterator/n_step_time_iterator.hpp +169 -0
- package/boost/numeric/odeint/iterator/times_iterator.hpp +189 -0
- package/boost/numeric/odeint/iterator/times_time_iterator.hpp +193 -0
- package/boost/numeric/odeint/stepper/adams_bashforth.hpp +418 -0
- package/boost/numeric/odeint/stepper/adams_bashforth_moulton.hpp +313 -0
- package/boost/numeric/odeint/stepper/adams_moulton.hpp +201 -0
- package/boost/numeric/odeint/stepper/adaptive_adams_bashforth_moulton.hpp +237 -0
- package/boost/numeric/odeint/stepper/base/algebra_stepper_base.hpp +91 -0
- package/boost/numeric/odeint/stepper/base/explicit_error_stepper_base.hpp +588 -0
- package/boost/numeric/odeint/stepper/base/explicit_error_stepper_fsal_base.hpp +677 -0
- package/boost/numeric/odeint/stepper/base/explicit_stepper_base.hpp +415 -0
- package/boost/numeric/odeint/stepper/base/symplectic_rkn_stepper_base.hpp +431 -0
- package/boost/numeric/odeint/stepper/bulirsch_stoer.hpp +642 -0
- package/boost/numeric/odeint/stepper/bulirsch_stoer_dense_out.hpp +838 -0
- package/boost/numeric/odeint/stepper/controlled_adams_bashforth_moulton.hpp +322 -0
- package/boost/numeric/odeint/stepper/controlled_runge_kutta.hpp +1018 -0
- package/boost/numeric/odeint/stepper/controlled_step_result.hpp +42 -0
- package/boost/numeric/odeint/stepper/dense_output_runge_kutta.hpp +476 -0
- package/boost/numeric/odeint/stepper/detail/adams_bashforth_call_algebra.hpp +148 -0
- package/boost/numeric/odeint/stepper/detail/adams_bashforth_coefficients.hpp +168 -0
- package/boost/numeric/odeint/stepper/detail/adams_moulton_call_algebra.hpp +148 -0
- package/boost/numeric/odeint/stepper/detail/adams_moulton_coefficients.hpp +168 -0
- package/boost/numeric/odeint/stepper/detail/adaptive_adams_coefficients.hpp +207 -0
- package/boost/numeric/odeint/stepper/detail/generic_rk_algorithm.hpp +247 -0
- package/boost/numeric/odeint/stepper/detail/generic_rk_call_algebra.hpp +263 -0
- package/boost/numeric/odeint/stepper/detail/generic_rk_operations.hpp +252 -0
- package/boost/numeric/odeint/stepper/detail/pid_step_adjuster.hpp +199 -0
- package/boost/numeric/odeint/stepper/detail/pid_step_adjuster_coefficients.hpp +180 -0
- package/boost/numeric/odeint/stepper/detail/rotating_buffer.hpp +84 -0
- package/boost/numeric/odeint/stepper/euler.hpp +166 -0
- package/boost/numeric/odeint/stepper/explicit_error_generic_rk.hpp +255 -0
- package/boost/numeric/odeint/stepper/explicit_generic_rk.hpp +246 -0
- package/boost/numeric/odeint/stepper/extrapolation_stepper.hpp +288 -0
- package/boost/numeric/odeint/stepper/generation/generation_controlled_adams_bashforth_moulton.hpp +59 -0
- package/boost/numeric/odeint/stepper/generation/generation_controlled_runge_kutta.hpp +61 -0
- package/boost/numeric/odeint/stepper/generation/generation_dense_output_runge_kutta.hpp +65 -0
- package/boost/numeric/odeint/stepper/generation/generation_rosenbrock4.hpp +79 -0
- package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_cash_karp54.hpp +47 -0
- package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_cash_karp54_classic.hpp +48 -0
- package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_dopri5.hpp +56 -0
- package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_fehlberg78.hpp +46 -0
- package/boost/numeric/odeint/stepper/generation/make_controlled.hpp +103 -0
- package/boost/numeric/odeint/stepper/generation/make_dense_output.hpp +100 -0
- package/boost/numeric/odeint/stepper/generation.hpp +37 -0
- package/boost/numeric/odeint/stepper/implicit_euler.hpp +170 -0
- package/boost/numeric/odeint/stepper/modified_midpoint.hpp +315 -0
- package/boost/numeric/odeint/stepper/rosenbrock4.hpp +346 -0
- package/boost/numeric/odeint/stepper/rosenbrock4_controller.hpp +240 -0
- package/boost/numeric/odeint/stepper/rosenbrock4_dense_output.hpp +204 -0
- package/boost/numeric/odeint/stepper/runge_kutta4.hpp +181 -0
- package/boost/numeric/odeint/stepper/runge_kutta4_classic.hpp +232 -0
- package/boost/numeric/odeint/stepper/runge_kutta_cash_karp54.hpp +231 -0
- package/boost/numeric/odeint/stepper/runge_kutta_cash_karp54_classic.hpp +289 -0
- package/boost/numeric/odeint/stepper/runge_kutta_dopri5.hpp +403 -0
- package/boost/numeric/odeint/stepper/runge_kutta_fehlberg78.hpp +374 -0
- package/boost/numeric/odeint/stepper/stepper_categories.hpp +66 -0
- package/boost/numeric/odeint/stepper/symplectic_euler.hpp +136 -0
- package/boost/numeric/odeint/stepper/symplectic_rkn_sb3a_m4_mclachlan.hpp +160 -0
- package/boost/numeric/odeint/stepper/symplectic_rkn_sb3a_mclachlan.hpp +162 -0
- package/boost/numeric/odeint/stepper/velocity_verlet.hpp +375 -0
- package/boost/numeric/odeint/tools/assert.hpp +30 -0
- package/boost/numeric/odeint/tools/is_standalone.hpp +21 -0
- package/boost/numeric/odeint/tools/traits.hpp +39 -0
- package/boost/numeric/odeint/util/bind.hpp +35 -0
- package/boost/numeric/odeint/util/copy.hpp +88 -0
- package/boost/numeric/odeint/util/detail/is_range.hpp +127 -0
- package/boost/numeric/odeint/util/detail/less_with_sign.hpp +78 -0
- package/boost/numeric/odeint/util/is_pair.hpp +42 -0
- package/boost/numeric/odeint/util/is_resizeable.hpp +84 -0
- package/boost/numeric/odeint/util/multi_array_adaption.hpp +131 -0
- package/boost/numeric/odeint/util/n_ary_helper.hpp +96 -0
- package/boost/numeric/odeint/util/odeint_error.hpp +77 -0
- package/boost/numeric/odeint/util/resize.hpp +120 -0
- package/boost/numeric/odeint/util/resizer.hpp +94 -0
- package/boost/numeric/odeint/util/same_instance.hpp +56 -0
- package/boost/numeric/odeint/util/same_size.hpp +117 -0
- package/boost/numeric/odeint/util/split.hpp +64 -0
- package/boost/numeric/odeint/util/split_adaptor.hpp +103 -0
- package/boost/numeric/odeint/util/state_wrapper.hpp +50 -0
- package/boost/numeric/odeint/util/stepper_traits.hpp +63 -0
- package/boost/numeric/odeint/util/ublas_matrix_expression.patch +6 -0
- package/boost/numeric/odeint/util/ublas_wrapper.hpp +297 -0
- package/boost/numeric/odeint/util/unit_helper.hpp +151 -0
- package/boost/numeric/odeint/util/unwrap_reference.hpp +141 -0
- package/boost/numeric/odeint/version.hpp +55 -0
- package/boost/numeric/odeint.hpp +87 -0
- package/boost/numeric/ublas/assignment.hpp +1288 -0
- package/boost/numeric/ublas/banded.hpp +2372 -0
- package/boost/numeric/ublas/blas.hpp +499 -0
- package/boost/numeric/ublas/detail/concepts.hpp +1465 -0
- package/boost/numeric/ublas/detail/config.hpp +304 -0
- package/boost/numeric/ublas/detail/definitions.hpp +212 -0
- package/boost/numeric/ublas/detail/documentation.hpp +33 -0
- package/boost/numeric/ublas/detail/duff.hpp +56 -0
- package/boost/numeric/ublas/detail/iterator.hpp +1448 -0
- package/boost/numeric/ublas/detail/matrix_assign.hpp +1785 -0
- package/boost/numeric/ublas/detail/raw.hpp +878 -0
- package/boost/numeric/ublas/detail/returntype_deduction.hpp +174 -0
- package/boost/numeric/ublas/detail/temporary.hpp +33 -0
- package/boost/numeric/ublas/detail/vector_assign.hpp +609 -0
- package/boost/numeric/ublas/doxydoc.hpp +58 -0
- package/boost/numeric/ublas/exception.hpp +297 -0
- package/boost/numeric/ublas/experimental/sparse_view.hpp +317 -0
- package/boost/numeric/ublas/expression_types.hpp +506 -0
- package/boost/numeric/ublas/functional.hpp +2112 -0
- package/boost/numeric/ublas/fwd.hpp +229 -0
- package/boost/numeric/ublas/hermitian.hpp +2633 -0
- package/boost/numeric/ublas/io.hpp +355 -0
- package/boost/numeric/ublas/lu.hpp +350 -0
- package/boost/numeric/ublas/matrix.hpp +6013 -0
- package/boost/numeric/ublas/matrix_expression.hpp +5693 -0
- package/boost/numeric/ublas/matrix_proxy.hpp +5457 -0
- package/boost/numeric/ublas/matrix_sparse.hpp +5773 -0
- package/boost/numeric/ublas/matrix_vector.hpp +406 -0
- package/boost/numeric/ublas/opencl/elementwise.hpp +508 -0
- package/boost/numeric/ublas/opencl/library.hpp +38 -0
- package/boost/numeric/ublas/opencl/matrix.hpp +123 -0
- package/boost/numeric/ublas/opencl/misc.hpp +182 -0
- package/boost/numeric/ublas/opencl/operations.hpp +18 -0
- package/boost/numeric/ublas/opencl/prod.hpp +364 -0
- package/boost/numeric/ublas/opencl/transpose.hpp +142 -0
- package/boost/numeric/ublas/opencl/vector.hpp +90 -0
- package/boost/numeric/ublas/opencl.hpp +16 -0
- package/boost/numeric/ublas/operation/begin.hpp +318 -0
- package/boost/numeric/ublas/operation/c_array.hpp +41 -0
- package/boost/numeric/ublas/operation/end.hpp +318 -0
- package/boost/numeric/ublas/operation/num_columns.hpp +45 -0
- package/boost/numeric/ublas/operation/num_rows.hpp +44 -0
- package/boost/numeric/ublas/operation/size.hpp +350 -0
- package/boost/numeric/ublas/operation.hpp +830 -0
- package/boost/numeric/ublas/operation_blocked.hpp +266 -0
- package/boost/numeric/ublas/operation_sparse.hpp +198 -0
- package/boost/numeric/ublas/operations.hpp +26 -0
- package/boost/numeric/ublas/storage.hpp +2131 -0
- package/boost/numeric/ublas/storage_sparse.hpp +578 -0
- package/boost/numeric/ublas/symmetric.hpp +2309 -0
- package/boost/numeric/ublas/tags.hpp +37 -0
- package/boost/numeric/ublas/tensor/algorithms.hpp +345 -0
- package/boost/numeric/ublas/tensor/expression.hpp +181 -0
- package/boost/numeric/ublas/tensor/expression_evaluation.hpp +288 -0
- package/boost/numeric/ublas/tensor/extents.hpp +335 -0
- package/boost/numeric/ublas/tensor/functions.hpp +558 -0
- package/boost/numeric/ublas/tensor/index.hpp +89 -0
- package/boost/numeric/ublas/tensor/multi_index.hpp +110 -0
- package/boost/numeric/ublas/tensor/multi_index_utility.hpp +364 -0
- package/boost/numeric/ublas/tensor/multiplication.hpp +945 -0
- package/boost/numeric/ublas/tensor/operators_arithmetic.hpp +244 -0
- package/boost/numeric/ublas/tensor/operators_comparison.hpp +175 -0
- package/boost/numeric/ublas/tensor/ostream.hpp +122 -0
- package/boost/numeric/ublas/tensor/storage_traits.hpp +84 -0
- package/boost/numeric/ublas/tensor/strides.hpp +251 -0
- package/boost/numeric/ublas/tensor/tensor.hpp +734 -0
- package/boost/numeric/ublas/tensor.hpp +26 -0
- package/boost/numeric/ublas/traits/c_array.hpp +110 -0
- package/boost/numeric/ublas/traits/const_iterator_type.hpp +127 -0
- package/boost/numeric/ublas/traits/iterator_type.hpp +126 -0
- package/boost/numeric/ublas/traits.hpp +753 -0
- package/boost/numeric/ublas/triangular.hpp +2775 -0
- package/boost/numeric/ublas/vector.hpp +2947 -0
- package/boost/numeric/ublas/vector_expression.hpp +1762 -0
- package/boost/numeric/ublas/vector_of_vector.hpp +1347 -0
- package/boost/numeric/ublas/vector_proxy.hpp +1697 -0
- package/boost/numeric/ublas/vector_sparse.hpp +2246 -0
- package/package.json +3 -7
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
/*
|
|
2
|
+
[auto_generated]
|
|
3
|
+
boost/numeric/odeint/stepper/adams_bashforth_moulton.hpp
|
|
4
|
+
|
|
5
|
+
[begin_description]
|
|
6
|
+
Implementation of the Adams-Bashforth-Moulton method, a predictor-corrector multistep method.
|
|
7
|
+
[end_description]
|
|
8
|
+
|
|
9
|
+
Copyright 2011-2013 Karsten Ahnert
|
|
10
|
+
Copyright 2011-2013 Mario Mulansky
|
|
11
|
+
Copyright 2012 Christoph Koke
|
|
12
|
+
|
|
13
|
+
Distributed under the Boost Software License, Version 1.0.
|
|
14
|
+
(See accompanying file LICENSE_1_0.txt or
|
|
15
|
+
copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
#ifndef BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_BASHFORTH_MOULTON_HPP_INCLUDED
|
|
20
|
+
#define BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_BASHFORTH_MOULTON_HPP_INCLUDED
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
#include <boost/numeric/odeint/util/bind.hpp>
|
|
24
|
+
|
|
25
|
+
#include <boost/numeric/odeint/stepper/stepper_categories.hpp>
|
|
26
|
+
#include <boost/numeric/odeint/algebra/range_algebra.hpp>
|
|
27
|
+
#include <boost/numeric/odeint/algebra/default_operations.hpp>
|
|
28
|
+
#include <boost/numeric/odeint/algebra/algebra_dispatcher.hpp>
|
|
29
|
+
#include <boost/numeric/odeint/algebra/operations_dispatcher.hpp>
|
|
30
|
+
|
|
31
|
+
#include <boost/numeric/odeint/util/state_wrapper.hpp>
|
|
32
|
+
#include <boost/numeric/odeint/util/resizer.hpp>
|
|
33
|
+
|
|
34
|
+
#include <boost/numeric/odeint/stepper/adams_bashforth.hpp>
|
|
35
|
+
#include <boost/numeric/odeint/stepper/adams_moulton.hpp>
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
namespace boost {
|
|
40
|
+
namespace numeric {
|
|
41
|
+
namespace odeint {
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
template<
|
|
45
|
+
size_t Steps ,
|
|
46
|
+
class State ,
|
|
47
|
+
class Value = double ,
|
|
48
|
+
class Deriv = State ,
|
|
49
|
+
class Time = Value ,
|
|
50
|
+
class Algebra = typename algebra_dispatcher< State >::algebra_type ,
|
|
51
|
+
class Operations = typename operations_dispatcher< State >::operations_type ,
|
|
52
|
+
class Resizer = initially_resizer,
|
|
53
|
+
class InitializingStepper = runge_kutta4< State , Value , Deriv , Time , Algebra , Operations, Resizer >
|
|
54
|
+
>
|
|
55
|
+
class adams_bashforth_moulton
|
|
56
|
+
{
|
|
57
|
+
|
|
58
|
+
#ifndef DOXYGEN_SKIP
|
|
59
|
+
static_assert(( Steps > 0 && Steps < 9 ), "Must have between 1 and 8 steps inclusive");
|
|
60
|
+
#endif
|
|
61
|
+
|
|
62
|
+
public :
|
|
63
|
+
|
|
64
|
+
typedef State state_type;
|
|
65
|
+
typedef state_wrapper< state_type > wrapped_state_type;
|
|
66
|
+
typedef Value value_type;
|
|
67
|
+
typedef Deriv deriv_type;
|
|
68
|
+
typedef state_wrapper< deriv_type > wrapped_deriv_type;
|
|
69
|
+
typedef Time time_type;
|
|
70
|
+
typedef Algebra algebra_type;
|
|
71
|
+
typedef Operations operations_type;
|
|
72
|
+
typedef Resizer resizer_type;
|
|
73
|
+
typedef stepper_tag stepper_category;
|
|
74
|
+
typedef InitializingStepper initializing_stepper_type;
|
|
75
|
+
|
|
76
|
+
static const size_t steps = Steps;
|
|
77
|
+
#ifndef DOXYGEN_SKIP
|
|
78
|
+
typedef adams_bashforth< steps , state_type , value_type , deriv_type , time_type , algebra_type , operations_type , resizer_type, initializing_stepper_type > adams_bashforth_type;
|
|
79
|
+
typedef adams_moulton< steps , state_type , value_type , deriv_type , time_type , algebra_type , operations_type , resizer_type > adams_moulton_type;
|
|
80
|
+
typedef adams_bashforth_moulton< steps , state_type , value_type , deriv_type , time_type , algebra_type , operations_type , resizer_type , initializing_stepper_type> stepper_type;
|
|
81
|
+
#endif //DOXYGEN_SKIP
|
|
82
|
+
typedef unsigned short order_type;
|
|
83
|
+
static const order_type order_value = steps;
|
|
84
|
+
|
|
85
|
+
/** \brief Constructs the adams_bashforth class. */
|
|
86
|
+
adams_bashforth_moulton( void )
|
|
87
|
+
: m_adams_bashforth() , m_adams_moulton( m_adams_bashforth.algebra() )
|
|
88
|
+
, m_x() , m_resizer()
|
|
89
|
+
{ }
|
|
90
|
+
|
|
91
|
+
adams_bashforth_moulton( const algebra_type &algebra )
|
|
92
|
+
: m_adams_bashforth( algebra ) , m_adams_moulton( m_adams_bashforth.algebra() )
|
|
93
|
+
, m_x() , m_resizer()
|
|
94
|
+
{ }
|
|
95
|
+
|
|
96
|
+
order_type order( void ) const { return order_value; }
|
|
97
|
+
|
|
98
|
+
template< class System , class StateInOut >
|
|
99
|
+
void do_step( System system , StateInOut &x , time_type t , time_type dt )
|
|
100
|
+
{
|
|
101
|
+
do_step_impl1( system , x , t , dt );
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* \brief Second version to solve the forwarding problem, can be called with Boost.Range as StateInOut.
|
|
106
|
+
*/
|
|
107
|
+
template< class System , class StateInOut >
|
|
108
|
+
void do_step( System system , const StateInOut &x , time_type t , time_type dt )
|
|
109
|
+
{
|
|
110
|
+
do_step_impl1( system , x , t , dt );
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
template< class System , class StateIn , class StateOut >
|
|
114
|
+
void do_step( System system , const StateIn &in , time_type t , const StateOut &out , time_type dt )
|
|
115
|
+
{
|
|
116
|
+
do_step_impl2( system , in , t , out , dt );
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* \brief Second version to solve the forwarding problem, can be called with Boost.Range as StateOut.
|
|
121
|
+
*/
|
|
122
|
+
template< class System , class StateIn , class StateOut >
|
|
123
|
+
void do_step( System system , const StateIn &in , time_type t , StateOut &out , time_type dt )
|
|
124
|
+
{
|
|
125
|
+
do_step_impl2( system , in ,t , out , dt );
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
template< class StateType >
|
|
130
|
+
void adjust_size( const StateType &x )
|
|
131
|
+
{
|
|
132
|
+
m_adams_bashforth.adjust_size( x );
|
|
133
|
+
m_adams_moulton.adjust_size( x );
|
|
134
|
+
resize_impl( x );
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
|
|
138
|
+
template< class ExplicitStepper , class System , class StateIn >
|
|
139
|
+
void initialize( ExplicitStepper explicit_stepper , System system , StateIn &x , time_type &t , time_type dt )
|
|
140
|
+
{
|
|
141
|
+
m_adams_bashforth.initialize( explicit_stepper , system , x , t , dt );
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
|
|
145
|
+
template< class System , class StateIn >
|
|
146
|
+
void initialize( System system , StateIn &x , time_type &t , time_type dt )
|
|
147
|
+
{
|
|
148
|
+
m_adams_bashforth.initialize( system , x , t , dt );
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
|
|
152
|
+
void reset(void)
|
|
153
|
+
{
|
|
154
|
+
m_adams_bashforth.reset();
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
private:
|
|
160
|
+
|
|
161
|
+
template< typename System , typename StateInOut >
|
|
162
|
+
void do_step_impl1( System system , StateInOut &x , time_type t , time_type dt )
|
|
163
|
+
{
|
|
164
|
+
if( m_adams_bashforth.is_initialized() )
|
|
165
|
+
{
|
|
166
|
+
m_resizer.adjust_size(x, [this](auto&& arg) { return this->resize_impl<StateInOut>(std::forward<decltype(arg)>(arg)); });
|
|
167
|
+
m_adams_bashforth.do_step( system , x , t , m_x.m_v , dt );
|
|
168
|
+
m_adams_moulton.do_step( system , x , m_x.m_v , t+dt , x , dt , m_adams_bashforth.step_storage() );
|
|
169
|
+
}
|
|
170
|
+
else
|
|
171
|
+
{
|
|
172
|
+
m_adams_bashforth.do_step( system , x , t , dt );
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
template< typename System , typename StateIn , typename StateInOut >
|
|
177
|
+
void do_step_impl2( System system , StateIn const &in , time_type t , StateInOut & out , time_type dt )
|
|
178
|
+
{
|
|
179
|
+
if( m_adams_bashforth.is_initialized() )
|
|
180
|
+
{
|
|
181
|
+
m_resizer.adjust_size(in, [this](auto&& arg) { return this->resize_impl<StateIn>(std::forward<decltype(arg)>(arg)); });
|
|
182
|
+
m_adams_bashforth.do_step( system , in , t , m_x.m_v , dt );
|
|
183
|
+
m_adams_moulton.do_step( system , in , m_x.m_v , t+dt , out , dt , m_adams_bashforth.step_storage() );
|
|
184
|
+
}
|
|
185
|
+
else
|
|
186
|
+
{
|
|
187
|
+
m_adams_bashforth.do_step( system , in , t , out , dt );
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
template< class StateIn >
|
|
193
|
+
bool resize_impl( const StateIn &x )
|
|
194
|
+
{
|
|
195
|
+
return adjust_size_by_resizeability( m_x , x , typename is_resizeable< state_type >::type() );
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
adams_bashforth_type m_adams_bashforth;
|
|
199
|
+
adams_moulton_type m_adams_moulton;
|
|
200
|
+
wrapped_state_type m_x;
|
|
201
|
+
resizer_type m_resizer;
|
|
202
|
+
};
|
|
203
|
+
|
|
204
|
+
|
|
205
|
+
/********* DOXYGEN ********/
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* \class adams_bashforth_moulton
|
|
209
|
+
* \brief The Adams-Bashforth-Moulton multistep algorithm.
|
|
210
|
+
*
|
|
211
|
+
* The Adams-Bashforth method is a multi-step predictor-corrector algorithm
|
|
212
|
+
* with configurable step number. The step number is specified as template
|
|
213
|
+
* parameter Steps and it then uses the result from the previous Steps steps.
|
|
214
|
+
* See also
|
|
215
|
+
* <a href="http://en.wikipedia.org/wiki/Linear_multistep_method">en.wikipedia.org/wiki/Linear_multistep_method</a>.
|
|
216
|
+
* Currently, a maximum of Steps=8 is supported.
|
|
217
|
+
* The method is explicit and fulfills the Stepper concept. Step size control
|
|
218
|
+
* or continuous output are not provided.
|
|
219
|
+
*
|
|
220
|
+
* This class derives from algebra_base and inherits its interface via
|
|
221
|
+
* CRTP (current recurring template pattern). For more details see
|
|
222
|
+
* algebra_stepper_base.
|
|
223
|
+
*
|
|
224
|
+
* \tparam Steps The number of steps (maximal 8).
|
|
225
|
+
* \tparam State The state type.
|
|
226
|
+
* \tparam Value The value type.
|
|
227
|
+
* \tparam Deriv The type representing the time derivative of the state.
|
|
228
|
+
* \tparam Time The time representing the independent variable - the time.
|
|
229
|
+
* \tparam Algebra The algebra type.
|
|
230
|
+
* \tparam Operations The operations type.
|
|
231
|
+
* \tparam Resizer The resizer policy type.
|
|
232
|
+
* \tparam InitializingStepper The stepper for the first two steps.
|
|
233
|
+
*/
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* \fn adams_bashforth_moulton::adams_bashforth_moulton( const algebra_type &algebra )
|
|
237
|
+
* \brief Constructs the adams_bashforth class. This constructor can be used as a default
|
|
238
|
+
* constructor if the algebra has a default constructor.
|
|
239
|
+
* \param algebra A copy of algebra is made and stored.
|
|
240
|
+
*/
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* \fn adams_bashforth_moulton::order( void ) const
|
|
244
|
+
* \brief Returns the order of the algorithm, which is equal to the number of steps+1.
|
|
245
|
+
* \return order of the method.
|
|
246
|
+
*/
|
|
247
|
+
|
|
248
|
+
/**
|
|
249
|
+
* \fn adams_bashforth_moulton::do_step( System system , StateInOut &x , time_type t , time_type dt )
|
|
250
|
+
* \brief This method performs one step. It transforms the result in-place.
|
|
251
|
+
*
|
|
252
|
+
* \param system The system function to solve, hence the r.h.s. of the ordinary differential equation. It must fulfill the
|
|
253
|
+
* Simple System concept.
|
|
254
|
+
* \param x The state of the ODE which should be solved. After calling do_step the result is updated in x.
|
|
255
|
+
* \param t The value of the time, at which the step should be performed.
|
|
256
|
+
* \param dt The step size.
|
|
257
|
+
*/
|
|
258
|
+
|
|
259
|
+
|
|
260
|
+
/**
|
|
261
|
+
* \fn adams_bashforth_moulton::do_step( System system , const StateIn &in , time_type t , const StateOut &out , time_type dt )
|
|
262
|
+
* \brief The method performs one step with the stepper passed by Stepper. The state of the ODE is updated out-of-place.
|
|
263
|
+
*
|
|
264
|
+
* \param system The system function to solve, hence the r.h.s. of the ODE. It must fulfill the
|
|
265
|
+
* Simple System concept.
|
|
266
|
+
* \param in The state of the ODE which should be solved. in is not modified in this method
|
|
267
|
+
* \param t The value of the time, at which the step should be performed.
|
|
268
|
+
* \param out The result of the step is written in out.
|
|
269
|
+
* \param dt The step size.
|
|
270
|
+
*/
|
|
271
|
+
|
|
272
|
+
/**
|
|
273
|
+
* \fn adams_bashforth_moulton::adjust_size( const StateType &x )
|
|
274
|
+
* \brief Adjust the size of all temporaries in the stepper manually.
|
|
275
|
+
* \param x A state from which the size of the temporaries to be resized is deduced.
|
|
276
|
+
*/
|
|
277
|
+
|
|
278
|
+
/**
|
|
279
|
+
* \fn adams_bashforth_moulton::initialize( ExplicitStepper explicit_stepper , System system , StateIn &x , time_type &t , time_type dt )
|
|
280
|
+
* \brief Initialized the stepper. Does Steps-1 steps with the explicit_stepper to fill the buffer.
|
|
281
|
+
* \note The state x and time t are updated to the values after Steps-1 initial steps.
|
|
282
|
+
* \param explicit_stepper the stepper used to fill the buffer of previous step results
|
|
283
|
+
* \param system The system function to solve, hence the r.h.s. of the ordinary differential equation. It must fulfill the
|
|
284
|
+
* Simple System concept.
|
|
285
|
+
* \param x The initial state of the ODE which should be solved, updated after in this method.
|
|
286
|
+
* \param t The initial time, updated in this method.
|
|
287
|
+
* \param dt The step size.
|
|
288
|
+
*/
|
|
289
|
+
|
|
290
|
+
/**
|
|
291
|
+
* \fn adams_bashforth_moulton::initialize( System system , StateIn &x , time_type &t , time_type dt )
|
|
292
|
+
* \brief Initialized the stepper. Does Steps-1 steps using the standard initializing stepper
|
|
293
|
+
* of the underlying adams_bashforth stepper.
|
|
294
|
+
* \param system The system function to solve, hence the r.h.s. of the ordinary differential equation. It must fulfill the
|
|
295
|
+
* Simple System concept.
|
|
296
|
+
* \param x The state of the ODE which should be solved. After calling do_step the result is updated in x.
|
|
297
|
+
* \param t The value of the time, at which the step should be performed.
|
|
298
|
+
* \param dt The step size.
|
|
299
|
+
*/
|
|
300
|
+
|
|
301
|
+
/**
|
|
302
|
+
* \fn adams_bashforth_moulton::reset( void )
|
|
303
|
+
* \brief Resets the internal buffers of the stepper.
|
|
304
|
+
*/
|
|
305
|
+
|
|
306
|
+
|
|
307
|
+
} // odeint
|
|
308
|
+
} // numeric
|
|
309
|
+
} // boost
|
|
310
|
+
|
|
311
|
+
|
|
312
|
+
|
|
313
|
+
#endif // BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_BASHFORTH_MOULTON_HPP_INCLUDED
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
/*
|
|
2
|
+
[auto_generated]
|
|
3
|
+
boost/numeric/odeint/stepper/adams_moulton.hpp
|
|
4
|
+
|
|
5
|
+
[begin_description]
|
|
6
|
+
Implementation of the Adams-Moulton method. This is method is not a real stepper, it is more a helper class
|
|
7
|
+
which computes the corrector step in the Adams-Bashforth-Moulton method.
|
|
8
|
+
[end_description]
|
|
9
|
+
|
|
10
|
+
Copyright 2011-2012 Karsten Ahnert
|
|
11
|
+
Copyright 2011-2013 Mario Mulansky
|
|
12
|
+
Copyright 2012 Christoph Koke
|
|
13
|
+
|
|
14
|
+
Distributed under the Boost Software License, Version 1.0.
|
|
15
|
+
(See accompanying file LICENSE_1_0.txt or
|
|
16
|
+
copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
#ifndef BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_MOULTON_HPP_INCLUDED
|
|
21
|
+
#define BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_MOULTON_HPP_INCLUDED
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
#include <boost/numeric/odeint/util/bind.hpp>
|
|
25
|
+
|
|
26
|
+
#include <boost/numeric/odeint/algebra/range_algebra.hpp>
|
|
27
|
+
#include <boost/numeric/odeint/algebra/default_operations.hpp>
|
|
28
|
+
#include <boost/numeric/odeint/algebra/algebra_dispatcher.hpp>
|
|
29
|
+
#include <boost/numeric/odeint/algebra/operations_dispatcher.hpp>
|
|
30
|
+
|
|
31
|
+
#include <boost/numeric/odeint/util/state_wrapper.hpp>
|
|
32
|
+
#include <boost/numeric/odeint/util/is_resizeable.hpp>
|
|
33
|
+
#include <boost/numeric/odeint/util/resizer.hpp>
|
|
34
|
+
|
|
35
|
+
#include <boost/numeric/odeint/stepper/stepper_categories.hpp>
|
|
36
|
+
#include <boost/numeric/odeint/stepper/runge_kutta4_classic.hpp>
|
|
37
|
+
|
|
38
|
+
#include <boost/numeric/odeint/stepper/detail/adams_moulton_call_algebra.hpp>
|
|
39
|
+
#include <boost/numeric/odeint/stepper/detail/adams_moulton_coefficients.hpp>
|
|
40
|
+
#include <boost/numeric/odeint/stepper/detail/rotating_buffer.hpp>
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
namespace boost {
|
|
46
|
+
namespace numeric {
|
|
47
|
+
namespace odeint {
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
/*
|
|
51
|
+
* Static implicit Adams-Moulton multistep-solver without step size control and without dense output.
|
|
52
|
+
*/
|
|
53
|
+
template<
|
|
54
|
+
size_t Steps ,
|
|
55
|
+
class State ,
|
|
56
|
+
class Value = double ,
|
|
57
|
+
class Deriv = State ,
|
|
58
|
+
class Time = Value ,
|
|
59
|
+
class Algebra = typename algebra_dispatcher< State >::algebra_type ,
|
|
60
|
+
class Operations = typename operations_dispatcher< State >::operations_type ,
|
|
61
|
+
class Resizer = initially_resizer
|
|
62
|
+
>
|
|
63
|
+
class adams_moulton
|
|
64
|
+
{
|
|
65
|
+
private:
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
public :
|
|
69
|
+
|
|
70
|
+
typedef State state_type;
|
|
71
|
+
typedef state_wrapper< state_type > wrapped_state_type;
|
|
72
|
+
typedef Value value_type;
|
|
73
|
+
typedef Deriv deriv_type;
|
|
74
|
+
typedef state_wrapper< deriv_type > wrapped_deriv_type;
|
|
75
|
+
typedef Time time_type;
|
|
76
|
+
typedef Algebra algebra_type;
|
|
77
|
+
typedef Operations operations_type;
|
|
78
|
+
typedef Resizer resizer_type;
|
|
79
|
+
typedef stepper_tag stepper_category;
|
|
80
|
+
|
|
81
|
+
typedef adams_moulton< Steps , State , Value , Deriv , Time , Algebra , Operations , Resizer > stepper_type;
|
|
82
|
+
|
|
83
|
+
static const size_t steps = Steps;
|
|
84
|
+
|
|
85
|
+
typedef unsigned short order_type;
|
|
86
|
+
static const order_type order_value = steps + 1;
|
|
87
|
+
|
|
88
|
+
typedef detail::rotating_buffer< wrapped_deriv_type , steps > step_storage_type;
|
|
89
|
+
|
|
90
|
+
adams_moulton( )
|
|
91
|
+
: m_coefficients() , m_dxdt() , m_resizer() ,
|
|
92
|
+
m_algebra_instance() , m_algebra( m_algebra_instance )
|
|
93
|
+
{ }
|
|
94
|
+
|
|
95
|
+
adams_moulton( algebra_type &algebra )
|
|
96
|
+
: m_coefficients() , m_dxdt() , m_resizer() ,
|
|
97
|
+
m_algebra_instance() , m_algebra( algebra )
|
|
98
|
+
{ }
|
|
99
|
+
|
|
100
|
+
adams_moulton& operator=( const adams_moulton &stepper )
|
|
101
|
+
{
|
|
102
|
+
m_dxdt = stepper.m_dxdt;
|
|
103
|
+
m_resizer = stepper.m_resizer;
|
|
104
|
+
m_algebra = stepper.m_algebra;
|
|
105
|
+
return *this;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
order_type order( void ) const { return order_value; }
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
/*
|
|
112
|
+
* Version 1 : do_step( system , x , t , dt , buf );
|
|
113
|
+
*
|
|
114
|
+
* solves the forwarding problem
|
|
115
|
+
*/
|
|
116
|
+
template< class System , class StateInOut , class StateIn , class ABBuf >
|
|
117
|
+
void do_step( System system , StateInOut &x , StateIn const & pred , time_type t , time_type dt , const ABBuf &buf )
|
|
118
|
+
{
|
|
119
|
+
do_step( system , x , pred , t , x , dt , buf );
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
template< class System , class StateInOut , class StateIn , class ABBuf >
|
|
123
|
+
void do_step( System system , const StateInOut &x , StateIn const & pred , time_type t , time_type dt , const ABBuf &buf )
|
|
124
|
+
{
|
|
125
|
+
do_step( system , x , pred , t , x , dt , buf );
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
|
|
130
|
+
/*
|
|
131
|
+
* Version 2 : do_step( system , in , t , out , dt , buf );
|
|
132
|
+
*
|
|
133
|
+
* solves the forwarding problem
|
|
134
|
+
*/
|
|
135
|
+
template< class System , class StateIn , class PredIn , class StateOut , class ABBuf >
|
|
136
|
+
void do_step( System system , const StateIn &in , const PredIn &pred , time_type t , StateOut &out , time_type dt , const ABBuf &buf )
|
|
137
|
+
{
|
|
138
|
+
do_step_impl( system , in , pred , t , out , dt , buf );
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
template< class System , class StateIn , class PredIn , class StateOut , class ABBuf >
|
|
142
|
+
void do_step( System system , const StateIn &in , const PredIn &pred , time_type t , const StateOut &out , time_type dt , const ABBuf &buf )
|
|
143
|
+
{
|
|
144
|
+
do_step_impl( system , in , pred , t , out , dt , buf );
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
|
|
148
|
+
|
|
149
|
+
template< class StateType >
|
|
150
|
+
void adjust_size( const StateType &x )
|
|
151
|
+
{
|
|
152
|
+
resize_impl( x );
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
algebra_type& algebra()
|
|
156
|
+
{ return m_algebra; }
|
|
157
|
+
|
|
158
|
+
const algebra_type& algebra() const
|
|
159
|
+
{ return m_algebra; }
|
|
160
|
+
|
|
161
|
+
|
|
162
|
+
private:
|
|
163
|
+
|
|
164
|
+
|
|
165
|
+
template< class System , class StateIn , class PredIn , class StateOut , class ABBuf >
|
|
166
|
+
void do_step_impl( System system , const StateIn &in , const PredIn &pred , time_type t , StateOut &out , time_type dt , const ABBuf &buf )
|
|
167
|
+
{
|
|
168
|
+
typename odeint::unwrap_reference< System >::type &sys = system;
|
|
169
|
+
m_resizer.adjust_size(in, [this](auto&& arg) { return this->resize_impl<StateIn>(std::forward<decltype(arg)>(arg)); });
|
|
170
|
+
sys( pred , m_dxdt.m_v , t );
|
|
171
|
+
detail::adams_moulton_call_algebra< steps , algebra_type , operations_type >()( m_algebra , in , out , m_dxdt.m_v , buf , m_coefficients , dt );
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
template< class StateIn >
|
|
176
|
+
bool resize_impl( const StateIn &x )
|
|
177
|
+
{
|
|
178
|
+
return adjust_size_by_resizeability( m_dxdt , x , typename is_resizeable<deriv_type>::type() );
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
const detail::adams_moulton_coefficients< value_type , steps > m_coefficients;
|
|
183
|
+
wrapped_deriv_type m_dxdt;
|
|
184
|
+
resizer_type m_resizer;
|
|
185
|
+
|
|
186
|
+
protected:
|
|
187
|
+
|
|
188
|
+
algebra_type m_algebra_instance;
|
|
189
|
+
algebra_type &m_algebra;
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
|
|
193
|
+
|
|
194
|
+
|
|
195
|
+
} // odeint
|
|
196
|
+
} // numeric
|
|
197
|
+
} // boost
|
|
198
|
+
|
|
199
|
+
|
|
200
|
+
|
|
201
|
+
#endif // BOOST_NUMERIC_ODEINT_STEPPER_ADAMS_MOULTON_HPP_INCLUDED
|