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.
Files changed (327) hide show
  1. package/README.md +29 -2
  2. package/boost/cast.hpp +20 -0
  3. package/boost/numeric/conversion/bounds.hpp +24 -0
  4. package/boost/numeric/conversion/cast.hpp +61 -0
  5. package/boost/numeric/conversion/conversion_traits.hpp +32 -0
  6. package/boost/numeric/conversion/converter.hpp +68 -0
  7. package/boost/numeric/conversion/converter_policies.hpp +194 -0
  8. package/boost/numeric/conversion/detail/bounds.hpp +58 -0
  9. package/boost/numeric/conversion/detail/conversion_traits.hpp +97 -0
  10. package/boost/numeric/conversion/detail/converter.hpp +593 -0
  11. package/boost/numeric/conversion/detail/int_float_mixture.hpp +72 -0
  12. package/boost/numeric/conversion/detail/is_subranged.hpp +234 -0
  13. package/boost/numeric/conversion/detail/meta.hpp +120 -0
  14. package/boost/numeric/conversion/detail/numeric_cast_traits.hpp +138 -0
  15. package/boost/numeric/conversion/detail/old_numeric_cast.hpp +308 -0
  16. package/boost/numeric/conversion/detail/preprocessed/numeric_cast_traits_common.hpp +1741 -0
  17. package/boost/numeric/conversion/detail/preprocessed/numeric_cast_traits_long_long.hpp +347 -0
  18. package/boost/numeric/conversion/detail/sign_mixture.hpp +72 -0
  19. package/boost/numeric/conversion/detail/udt_builtin_mixture.hpp +69 -0
  20. package/boost/numeric/conversion/int_float_mixture.hpp +30 -0
  21. package/boost/numeric/conversion/int_float_mixture_enum.hpp +29 -0
  22. package/boost/numeric/conversion/is_subranged.hpp +27 -0
  23. package/boost/numeric/conversion/numeric_cast_traits.hpp +31 -0
  24. package/boost/numeric/conversion/sign_mixture.hpp +30 -0
  25. package/boost/numeric/conversion/sign_mixture_enum.hpp +29 -0
  26. package/boost/numeric/conversion/udt_builtin_mixture.hpp +28 -0
  27. package/boost/numeric/conversion/udt_builtin_mixture_enum.hpp +26 -0
  28. package/boost/numeric/interval/arith.hpp +305 -0
  29. package/boost/numeric/interval/arith2.hpp +304 -0
  30. package/boost/numeric/interval/arith3.hpp +69 -0
  31. package/boost/numeric/interval/checking.hpp +130 -0
  32. package/boost/numeric/interval/compare/certain.hpp +113 -0
  33. package/boost/numeric/interval/compare/explicit.hpp +248 -0
  34. package/boost/numeric/interval/compare/lexicographic.hpp +122 -0
  35. package/boost/numeric/interval/compare/possible.hpp +113 -0
  36. package/boost/numeric/interval/compare/set.hpp +101 -0
  37. package/boost/numeric/interval/compare/tribool.hpp +138 -0
  38. package/boost/numeric/interval/compare.hpp +19 -0
  39. package/boost/numeric/interval/constants.hpp +85 -0
  40. package/boost/numeric/interval/detail/alpha_rounding_control.hpp +113 -0
  41. package/boost/numeric/interval/detail/bcc_rounding_control.hpp +57 -0
  42. package/boost/numeric/interval/detail/bugs.hpp +48 -0
  43. package/boost/numeric/interval/detail/c99_rounding_control.hpp +50 -0
  44. package/boost/numeric/interval/detail/c99sub_rounding_control.hpp +43 -0
  45. package/boost/numeric/interval/detail/division.hpp +194 -0
  46. package/boost/numeric/interval/detail/ia64_rounding_control.hpp +83 -0
  47. package/boost/numeric/interval/detail/interval_prototype.hpp +41 -0
  48. package/boost/numeric/interval/detail/msvc_rounding_control.hpp +113 -0
  49. package/boost/numeric/interval/detail/ppc_rounding_control.hpp +99 -0
  50. package/boost/numeric/interval/detail/sparc_rounding_control.hpp +112 -0
  51. package/boost/numeric/interval/detail/test_input.hpp +76 -0
  52. package/boost/numeric/interval/detail/x86_rounding_control.hpp +108 -0
  53. package/boost/numeric/interval/detail/x86gcc_rounding_control.hpp +51 -0
  54. package/boost/numeric/interval/ext/integer.hpp +70 -0
  55. package/boost/numeric/interval/ext/x86_fast_rounding_control.hpp +70 -0
  56. package/boost/numeric/interval/hw_rounding.hpp +73 -0
  57. package/boost/numeric/interval/interval.hpp +450 -0
  58. package/boost/numeric/interval/io.hpp +41 -0
  59. package/boost/numeric/interval/limits.hpp +49 -0
  60. package/boost/numeric/interval/policies.hpp +75 -0
  61. package/boost/numeric/interval/rounded_arith.hpp +120 -0
  62. package/boost/numeric/interval/rounded_transc.hpp +140 -0
  63. package/boost/numeric/interval/rounding.hpp +101 -0
  64. package/boost/numeric/interval/transc.hpp +232 -0
  65. package/boost/numeric/interval/utility.hpp +335 -0
  66. package/boost/numeric/interval/utility_fwd.hpp +172 -0
  67. package/boost/numeric/interval.hpp +32 -0
  68. package/boost/numeric/odeint/algebra/algebra_dispatcher.hpp +86 -0
  69. package/boost/numeric/odeint/algebra/array_algebra.hpp +293 -0
  70. package/boost/numeric/odeint/algebra/default_operations.hpp +599 -0
  71. package/boost/numeric/odeint/algebra/detail/extract_value_type.hpp +51 -0
  72. package/boost/numeric/odeint/algebra/detail/for_each.hpp +165 -0
  73. package/boost/numeric/odeint/algebra/detail/macros.hpp +35 -0
  74. package/boost/numeric/odeint/algebra/detail/norm_inf.hpp +46 -0
  75. package/boost/numeric/odeint/algebra/fusion_algebra.hpp +216 -0
  76. package/boost/numeric/odeint/algebra/fusion_algebra_dispatcher.hpp +48 -0
  77. package/boost/numeric/odeint/algebra/multi_array_algebra.hpp +146 -0
  78. package/boost/numeric/odeint/algebra/norm_result_type.hpp +33 -0
  79. package/boost/numeric/odeint/algebra/operations_dispatcher.hpp +41 -0
  80. package/boost/numeric/odeint/algebra/range_algebra.hpp +142 -0
  81. package/boost/numeric/odeint/algebra/vector_space_algebra.hpp +175 -0
  82. package/boost/numeric/odeint/config.hpp +53 -0
  83. package/boost/numeric/odeint/external/blaze/blaze_algebra_dispatcher.hpp +55 -0
  84. package/boost/numeric/odeint/external/blaze/blaze_resize.hpp +64 -0
  85. package/boost/numeric/odeint/external/compute/compute.hpp +27 -0
  86. package/boost/numeric/odeint/external/compute/compute_algebra.hpp +65 -0
  87. package/boost/numeric/odeint/external/compute/compute_algebra_dispatcher.hpp +41 -0
  88. package/boost/numeric/odeint/external/compute/compute_operations.hpp +198 -0
  89. package/boost/numeric/odeint/external/compute/compute_operations_dispatcher.hpp +44 -0
  90. package/boost/numeric/odeint/external/compute/compute_resize.hpp +92 -0
  91. package/boost/numeric/odeint/external/eigen/eigen.hpp +27 -0
  92. package/boost/numeric/odeint/external/eigen/eigen_algebra.hpp +98 -0
  93. package/boost/numeric/odeint/external/eigen/eigen_algebra_dispatcher.hpp +49 -0
  94. package/boost/numeric/odeint/external/eigen/eigen_resize.hpp +103 -0
  95. package/boost/numeric/odeint/external/gsl/gsl_wrapper.hpp +228 -0
  96. package/boost/numeric/odeint/external/mkl/mkl_operations.hpp +181 -0
  97. package/boost/numeric/odeint/external/mpi/mpi.hpp +25 -0
  98. package/boost/numeric/odeint/external/mpi/mpi_nested_algebra.hpp +62 -0
  99. package/boost/numeric/odeint/external/mpi/mpi_state.hpp +113 -0
  100. package/boost/numeric/odeint/external/mpi/mpi_vector_state.hpp +95 -0
  101. package/boost/numeric/odeint/external/mtl4/implicit_euler_mtl4.hpp +161 -0
  102. package/boost/numeric/odeint/external/mtl4/mtl4.hpp +23 -0
  103. package/boost/numeric/odeint/external/mtl4/mtl4_algebra_dispatcher.hpp +99 -0
  104. package/boost/numeric/odeint/external/mtl4/mtl4_resize.hpp +134 -0
  105. package/boost/numeric/odeint/external/nt2/nt2_algebra_dispatcher.hpp +25 -0
  106. package/boost/numeric/odeint/external/nt2/nt2_copy.hpp +33 -0
  107. package/boost/numeric/odeint/external/nt2/nt2_norm_inf.hpp +31 -0
  108. package/boost/numeric/odeint/external/nt2/nt2_resize.hpp +54 -0
  109. package/boost/numeric/odeint/external/openmp/openmp.hpp +31 -0
  110. package/boost/numeric/odeint/external/openmp/openmp_nested_algebra.hpp +281 -0
  111. package/boost/numeric/odeint/external/openmp/openmp_range_algebra.hpp +276 -0
  112. package/boost/numeric/odeint/external/openmp/openmp_state.hpp +172 -0
  113. package/boost/numeric/odeint/external/thrust/thrust.hpp +27 -0
  114. package/boost/numeric/odeint/external/thrust/thrust_algebra.hpp +217 -0
  115. package/boost/numeric/odeint/external/thrust/thrust_algebra_dispatcher.hpp +118 -0
  116. package/boost/numeric/odeint/external/thrust/thrust_operations.hpp +233 -0
  117. package/boost/numeric/odeint/external/thrust/thrust_operations_dispatcher.hpp +118 -0
  118. package/boost/numeric/odeint/external/thrust/thrust_resize.hpp +197 -0
  119. package/boost/numeric/odeint/external/vexcl/vexcl.hpp +28 -0
  120. package/boost/numeric/odeint/external/vexcl/vexcl_abs.hpp +61 -0
  121. package/boost/numeric/odeint/external/vexcl/vexcl_algebra_dispatcher.hpp +51 -0
  122. package/boost/numeric/odeint/external/vexcl/vexcl_copy.hpp +55 -0
  123. package/boost/numeric/odeint/external/vexcl/vexcl_norm_inf.hpp +68 -0
  124. package/boost/numeric/odeint/external/vexcl/vexcl_resize.hpp +96 -0
  125. package/boost/numeric/odeint/external/vexcl/vexcl_same_instance.hpp +58 -0
  126. package/boost/numeric/odeint/external/viennacl/viennacl_operations.hpp +226 -0
  127. package/boost/numeric/odeint/external/viennacl/viennacl_resize.hpp +68 -0
  128. package/boost/numeric/odeint/integrate/check_adapter.hpp +222 -0
  129. package/boost/numeric/odeint/integrate/detail/functors.hpp +70 -0
  130. package/boost/numeric/odeint/integrate/detail/integrate_adaptive.hpp +161 -0
  131. package/boost/numeric/odeint/integrate/detail/integrate_const.hpp +167 -0
  132. package/boost/numeric/odeint/integrate/detail/integrate_n_steps.hpp +161 -0
  133. package/boost/numeric/odeint/integrate/detail/integrate_times.hpp +179 -0
  134. package/boost/numeric/odeint/integrate/integrate.hpp +133 -0
  135. package/boost/numeric/odeint/integrate/integrate_adaptive.hpp +127 -0
  136. package/boost/numeric/odeint/integrate/integrate_const.hpp +195 -0
  137. package/boost/numeric/odeint/integrate/integrate_n_steps.hpp +178 -0
  138. package/boost/numeric/odeint/integrate/integrate_times.hpp +220 -0
  139. package/boost/numeric/odeint/integrate/max_step_checker.hpp +114 -0
  140. package/boost/numeric/odeint/integrate/null_observer.hpp +38 -0
  141. package/boost/numeric/odeint/integrate/observer_collection.hpp +55 -0
  142. package/boost/numeric/odeint/iterator/adaptive_iterator.hpp +183 -0
  143. package/boost/numeric/odeint/iterator/adaptive_time_iterator.hpp +175 -0
  144. package/boost/numeric/odeint/iterator/const_step_iterator.hpp +180 -0
  145. package/boost/numeric/odeint/iterator/const_step_time_iterator.hpp +173 -0
  146. package/boost/numeric/odeint/iterator/detail/ode_iterator_base.hpp +199 -0
  147. package/boost/numeric/odeint/iterator/impl/adaptive_iterator_impl.hpp +251 -0
  148. package/boost/numeric/odeint/iterator/impl/const_step_iterator_impl.hpp +228 -0
  149. package/boost/numeric/odeint/iterator/impl/n_step_iterator_impl.hpp +239 -0
  150. package/boost/numeric/odeint/iterator/impl/times_iterator_impl.hpp +369 -0
  151. package/boost/numeric/odeint/iterator/integrate/detail/functors.hpp +70 -0
  152. package/boost/numeric/odeint/iterator/integrate/detail/integrate_adaptive.hpp +121 -0
  153. package/boost/numeric/odeint/iterator/integrate/detail/integrate_const.hpp +111 -0
  154. package/boost/numeric/odeint/iterator/integrate/detail/integrate_n_steps.hpp +107 -0
  155. package/boost/numeric/odeint/iterator/integrate/detail/integrate_times.hpp +67 -0
  156. package/boost/numeric/odeint/iterator/integrate/integrate.hpp +111 -0
  157. package/boost/numeric/odeint/iterator/integrate/integrate_adaptive.hpp +127 -0
  158. package/boost/numeric/odeint/iterator/integrate/integrate_const.hpp +158 -0
  159. package/boost/numeric/odeint/iterator/integrate/integrate_n_steps.hpp +123 -0
  160. package/boost/numeric/odeint/iterator/integrate/integrate_times.hpp +131 -0
  161. package/boost/numeric/odeint/iterator/integrate/null_observer.hpp +38 -0
  162. package/boost/numeric/odeint/iterator/integrate/observer_collection.hpp +55 -0
  163. package/boost/numeric/odeint/iterator/n_step_iterator.hpp +168 -0
  164. package/boost/numeric/odeint/iterator/n_step_time_iterator.hpp +169 -0
  165. package/boost/numeric/odeint/iterator/times_iterator.hpp +189 -0
  166. package/boost/numeric/odeint/iterator/times_time_iterator.hpp +193 -0
  167. package/boost/numeric/odeint/stepper/adams_bashforth.hpp +418 -0
  168. package/boost/numeric/odeint/stepper/adams_bashforth_moulton.hpp +313 -0
  169. package/boost/numeric/odeint/stepper/adams_moulton.hpp +201 -0
  170. package/boost/numeric/odeint/stepper/adaptive_adams_bashforth_moulton.hpp +237 -0
  171. package/boost/numeric/odeint/stepper/base/algebra_stepper_base.hpp +91 -0
  172. package/boost/numeric/odeint/stepper/base/explicit_error_stepper_base.hpp +588 -0
  173. package/boost/numeric/odeint/stepper/base/explicit_error_stepper_fsal_base.hpp +677 -0
  174. package/boost/numeric/odeint/stepper/base/explicit_stepper_base.hpp +415 -0
  175. package/boost/numeric/odeint/stepper/base/symplectic_rkn_stepper_base.hpp +431 -0
  176. package/boost/numeric/odeint/stepper/bulirsch_stoer.hpp +642 -0
  177. package/boost/numeric/odeint/stepper/bulirsch_stoer_dense_out.hpp +838 -0
  178. package/boost/numeric/odeint/stepper/controlled_adams_bashforth_moulton.hpp +322 -0
  179. package/boost/numeric/odeint/stepper/controlled_runge_kutta.hpp +1018 -0
  180. package/boost/numeric/odeint/stepper/controlled_step_result.hpp +42 -0
  181. package/boost/numeric/odeint/stepper/dense_output_runge_kutta.hpp +476 -0
  182. package/boost/numeric/odeint/stepper/detail/adams_bashforth_call_algebra.hpp +148 -0
  183. package/boost/numeric/odeint/stepper/detail/adams_bashforth_coefficients.hpp +168 -0
  184. package/boost/numeric/odeint/stepper/detail/adams_moulton_call_algebra.hpp +148 -0
  185. package/boost/numeric/odeint/stepper/detail/adams_moulton_coefficients.hpp +168 -0
  186. package/boost/numeric/odeint/stepper/detail/adaptive_adams_coefficients.hpp +207 -0
  187. package/boost/numeric/odeint/stepper/detail/generic_rk_algorithm.hpp +247 -0
  188. package/boost/numeric/odeint/stepper/detail/generic_rk_call_algebra.hpp +263 -0
  189. package/boost/numeric/odeint/stepper/detail/generic_rk_operations.hpp +252 -0
  190. package/boost/numeric/odeint/stepper/detail/pid_step_adjuster.hpp +199 -0
  191. package/boost/numeric/odeint/stepper/detail/pid_step_adjuster_coefficients.hpp +180 -0
  192. package/boost/numeric/odeint/stepper/detail/rotating_buffer.hpp +84 -0
  193. package/boost/numeric/odeint/stepper/euler.hpp +166 -0
  194. package/boost/numeric/odeint/stepper/explicit_error_generic_rk.hpp +255 -0
  195. package/boost/numeric/odeint/stepper/explicit_generic_rk.hpp +246 -0
  196. package/boost/numeric/odeint/stepper/extrapolation_stepper.hpp +288 -0
  197. package/boost/numeric/odeint/stepper/generation/generation_controlled_adams_bashforth_moulton.hpp +59 -0
  198. package/boost/numeric/odeint/stepper/generation/generation_controlled_runge_kutta.hpp +61 -0
  199. package/boost/numeric/odeint/stepper/generation/generation_dense_output_runge_kutta.hpp +65 -0
  200. package/boost/numeric/odeint/stepper/generation/generation_rosenbrock4.hpp +79 -0
  201. package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_cash_karp54.hpp +47 -0
  202. package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_cash_karp54_classic.hpp +48 -0
  203. package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_dopri5.hpp +56 -0
  204. package/boost/numeric/odeint/stepper/generation/generation_runge_kutta_fehlberg78.hpp +46 -0
  205. package/boost/numeric/odeint/stepper/generation/make_controlled.hpp +103 -0
  206. package/boost/numeric/odeint/stepper/generation/make_dense_output.hpp +100 -0
  207. package/boost/numeric/odeint/stepper/generation.hpp +37 -0
  208. package/boost/numeric/odeint/stepper/implicit_euler.hpp +170 -0
  209. package/boost/numeric/odeint/stepper/modified_midpoint.hpp +315 -0
  210. package/boost/numeric/odeint/stepper/rosenbrock4.hpp +346 -0
  211. package/boost/numeric/odeint/stepper/rosenbrock4_controller.hpp +240 -0
  212. package/boost/numeric/odeint/stepper/rosenbrock4_dense_output.hpp +204 -0
  213. package/boost/numeric/odeint/stepper/runge_kutta4.hpp +181 -0
  214. package/boost/numeric/odeint/stepper/runge_kutta4_classic.hpp +232 -0
  215. package/boost/numeric/odeint/stepper/runge_kutta_cash_karp54.hpp +231 -0
  216. package/boost/numeric/odeint/stepper/runge_kutta_cash_karp54_classic.hpp +289 -0
  217. package/boost/numeric/odeint/stepper/runge_kutta_dopri5.hpp +403 -0
  218. package/boost/numeric/odeint/stepper/runge_kutta_fehlberg78.hpp +374 -0
  219. package/boost/numeric/odeint/stepper/stepper_categories.hpp +66 -0
  220. package/boost/numeric/odeint/stepper/symplectic_euler.hpp +136 -0
  221. package/boost/numeric/odeint/stepper/symplectic_rkn_sb3a_m4_mclachlan.hpp +160 -0
  222. package/boost/numeric/odeint/stepper/symplectic_rkn_sb3a_mclachlan.hpp +162 -0
  223. package/boost/numeric/odeint/stepper/velocity_verlet.hpp +375 -0
  224. package/boost/numeric/odeint/tools/assert.hpp +30 -0
  225. package/boost/numeric/odeint/tools/is_standalone.hpp +21 -0
  226. package/boost/numeric/odeint/tools/traits.hpp +39 -0
  227. package/boost/numeric/odeint/util/bind.hpp +35 -0
  228. package/boost/numeric/odeint/util/copy.hpp +88 -0
  229. package/boost/numeric/odeint/util/detail/is_range.hpp +127 -0
  230. package/boost/numeric/odeint/util/detail/less_with_sign.hpp +78 -0
  231. package/boost/numeric/odeint/util/is_pair.hpp +42 -0
  232. package/boost/numeric/odeint/util/is_resizeable.hpp +84 -0
  233. package/boost/numeric/odeint/util/multi_array_adaption.hpp +131 -0
  234. package/boost/numeric/odeint/util/n_ary_helper.hpp +96 -0
  235. package/boost/numeric/odeint/util/odeint_error.hpp +77 -0
  236. package/boost/numeric/odeint/util/resize.hpp +120 -0
  237. package/boost/numeric/odeint/util/resizer.hpp +94 -0
  238. package/boost/numeric/odeint/util/same_instance.hpp +56 -0
  239. package/boost/numeric/odeint/util/same_size.hpp +117 -0
  240. package/boost/numeric/odeint/util/split.hpp +64 -0
  241. package/boost/numeric/odeint/util/split_adaptor.hpp +103 -0
  242. package/boost/numeric/odeint/util/state_wrapper.hpp +50 -0
  243. package/boost/numeric/odeint/util/stepper_traits.hpp +63 -0
  244. package/boost/numeric/odeint/util/ublas_matrix_expression.patch +6 -0
  245. package/boost/numeric/odeint/util/ublas_wrapper.hpp +297 -0
  246. package/boost/numeric/odeint/util/unit_helper.hpp +151 -0
  247. package/boost/numeric/odeint/util/unwrap_reference.hpp +141 -0
  248. package/boost/numeric/odeint/version.hpp +55 -0
  249. package/boost/numeric/odeint.hpp +87 -0
  250. package/boost/numeric/ublas/assignment.hpp +1288 -0
  251. package/boost/numeric/ublas/banded.hpp +2372 -0
  252. package/boost/numeric/ublas/blas.hpp +499 -0
  253. package/boost/numeric/ublas/detail/concepts.hpp +1465 -0
  254. package/boost/numeric/ublas/detail/config.hpp +304 -0
  255. package/boost/numeric/ublas/detail/definitions.hpp +212 -0
  256. package/boost/numeric/ublas/detail/documentation.hpp +33 -0
  257. package/boost/numeric/ublas/detail/duff.hpp +56 -0
  258. package/boost/numeric/ublas/detail/iterator.hpp +1448 -0
  259. package/boost/numeric/ublas/detail/matrix_assign.hpp +1785 -0
  260. package/boost/numeric/ublas/detail/raw.hpp +878 -0
  261. package/boost/numeric/ublas/detail/returntype_deduction.hpp +174 -0
  262. package/boost/numeric/ublas/detail/temporary.hpp +33 -0
  263. package/boost/numeric/ublas/detail/vector_assign.hpp +609 -0
  264. package/boost/numeric/ublas/doxydoc.hpp +58 -0
  265. package/boost/numeric/ublas/exception.hpp +297 -0
  266. package/boost/numeric/ublas/experimental/sparse_view.hpp +317 -0
  267. package/boost/numeric/ublas/expression_types.hpp +506 -0
  268. package/boost/numeric/ublas/functional.hpp +2112 -0
  269. package/boost/numeric/ublas/fwd.hpp +229 -0
  270. package/boost/numeric/ublas/hermitian.hpp +2633 -0
  271. package/boost/numeric/ublas/io.hpp +355 -0
  272. package/boost/numeric/ublas/lu.hpp +350 -0
  273. package/boost/numeric/ublas/matrix.hpp +6013 -0
  274. package/boost/numeric/ublas/matrix_expression.hpp +5693 -0
  275. package/boost/numeric/ublas/matrix_proxy.hpp +5457 -0
  276. package/boost/numeric/ublas/matrix_sparse.hpp +5773 -0
  277. package/boost/numeric/ublas/matrix_vector.hpp +406 -0
  278. package/boost/numeric/ublas/opencl/elementwise.hpp +508 -0
  279. package/boost/numeric/ublas/opencl/library.hpp +38 -0
  280. package/boost/numeric/ublas/opencl/matrix.hpp +123 -0
  281. package/boost/numeric/ublas/opencl/misc.hpp +182 -0
  282. package/boost/numeric/ublas/opencl/operations.hpp +18 -0
  283. package/boost/numeric/ublas/opencl/prod.hpp +364 -0
  284. package/boost/numeric/ublas/opencl/transpose.hpp +142 -0
  285. package/boost/numeric/ublas/opencl/vector.hpp +90 -0
  286. package/boost/numeric/ublas/opencl.hpp +16 -0
  287. package/boost/numeric/ublas/operation/begin.hpp +318 -0
  288. package/boost/numeric/ublas/operation/c_array.hpp +41 -0
  289. package/boost/numeric/ublas/operation/end.hpp +318 -0
  290. package/boost/numeric/ublas/operation/num_columns.hpp +45 -0
  291. package/boost/numeric/ublas/operation/num_rows.hpp +44 -0
  292. package/boost/numeric/ublas/operation/size.hpp +350 -0
  293. package/boost/numeric/ublas/operation.hpp +830 -0
  294. package/boost/numeric/ublas/operation_blocked.hpp +266 -0
  295. package/boost/numeric/ublas/operation_sparse.hpp +198 -0
  296. package/boost/numeric/ublas/operations.hpp +26 -0
  297. package/boost/numeric/ublas/storage.hpp +2131 -0
  298. package/boost/numeric/ublas/storage_sparse.hpp +578 -0
  299. package/boost/numeric/ublas/symmetric.hpp +2309 -0
  300. package/boost/numeric/ublas/tags.hpp +37 -0
  301. package/boost/numeric/ublas/tensor/algorithms.hpp +345 -0
  302. package/boost/numeric/ublas/tensor/expression.hpp +181 -0
  303. package/boost/numeric/ublas/tensor/expression_evaluation.hpp +288 -0
  304. package/boost/numeric/ublas/tensor/extents.hpp +335 -0
  305. package/boost/numeric/ublas/tensor/functions.hpp +558 -0
  306. package/boost/numeric/ublas/tensor/index.hpp +89 -0
  307. package/boost/numeric/ublas/tensor/multi_index.hpp +110 -0
  308. package/boost/numeric/ublas/tensor/multi_index_utility.hpp +364 -0
  309. package/boost/numeric/ublas/tensor/multiplication.hpp +945 -0
  310. package/boost/numeric/ublas/tensor/operators_arithmetic.hpp +244 -0
  311. package/boost/numeric/ublas/tensor/operators_comparison.hpp +175 -0
  312. package/boost/numeric/ublas/tensor/ostream.hpp +122 -0
  313. package/boost/numeric/ublas/tensor/storage_traits.hpp +84 -0
  314. package/boost/numeric/ublas/tensor/strides.hpp +251 -0
  315. package/boost/numeric/ublas/tensor/tensor.hpp +734 -0
  316. package/boost/numeric/ublas/tensor.hpp +26 -0
  317. package/boost/numeric/ublas/traits/c_array.hpp +110 -0
  318. package/boost/numeric/ublas/traits/const_iterator_type.hpp +127 -0
  319. package/boost/numeric/ublas/traits/iterator_type.hpp +126 -0
  320. package/boost/numeric/ublas/traits.hpp +753 -0
  321. package/boost/numeric/ublas/triangular.hpp +2775 -0
  322. package/boost/numeric/ublas/vector.hpp +2947 -0
  323. package/boost/numeric/ublas/vector_expression.hpp +1762 -0
  324. package/boost/numeric/ublas/vector_of_vector.hpp +1347 -0
  325. package/boost/numeric/ublas/vector_proxy.hpp +1697 -0
  326. package/boost/numeric/ublas/vector_sparse.hpp +2246 -0
  327. 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