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,142 @@
1
+ // Boost.uBLAS
2
+ //
3
+ // Copyright (c) 2018 Fady Essam
4
+ // Copyright (c) 2018 Stefan Seefeld
5
+ //
6
+ // Distributed under the Boost Software License, Version 1.0.
7
+ // (See accompanying file LICENSE_1_0.txt or
8
+ // copy at http://www.boost.org/LICENSE_1_0.txt)
9
+
10
+ #ifndef boost_numeric_ublas_opencl_transpose_hpp_
11
+ #define boost_numeric_ublas_opencl_transpose_hpp_
12
+
13
+ #include <boost/numeric/ublas/opencl/library.hpp>
14
+ #include <boost/numeric/ublas/opencl/vector.hpp>
15
+ #include <boost/numeric/ublas/opencl/matrix.hpp>
16
+
17
+ // Kernel for transposition of various data types
18
+ #define OPENCL_TRANSPOSITION_KERNEL(DATA_TYPE) \
19
+ "__kernel void transpose(__global " #DATA_TYPE "* in, __global " #DATA_TYPE "* result, unsigned int width, unsigned int height) \n" \
20
+ "{ \n" \
21
+ " unsigned int column_index = get_global_id(0); \n" \
22
+ " unsigned int row_index = get_global_id(1); \n" \
23
+ " if (column_index < width && row_index < height) \n" \
24
+ " { \n" \
25
+ " unsigned int index_in = column_index + width * row_index; \n" \
26
+ " unsigned int index_result = row_index + height * column_index; \n" \
27
+ " result[index_result] = in[index_in]; \n" \
28
+ " } \n" \
29
+ "} \n"
30
+
31
+
32
+ namespace boost { namespace numeric { namespace ublas { namespace opencl {
33
+
34
+ template<class T, class L1, class L2>
35
+ typename std::enable_if<is_numeric<T>::value>::type
36
+ change_layout(ublas::matrix<T, L1, opencl::storage> const &m,
37
+ ublas::matrix<T, L2, opencl::storage> &result,
38
+ compute::command_queue& queue)
39
+ {
40
+ assert(m.size1() == result.size1() && m.size2() == result.size2());
41
+ assert(m.device() == result.device() && m.device() == queue.get_device());
42
+ assert(!(std::is_same<L1, L2>::value));
43
+ char const *kernel;
44
+ if (std::is_same<T, float>::value)
45
+ kernel = OPENCL_TRANSPOSITION_KERNEL(float);
46
+ else if (std::is_same<T, double>::value)
47
+ kernel = OPENCL_TRANSPOSITION_KERNEL(double);
48
+ else if (std::is_same<T, std::complex<float>>::value)
49
+ kernel = OPENCL_TRANSPOSITION_KERNEL(float2);
50
+ else if (std::is_same<T, std::complex<double>>::value)
51
+ kernel = OPENCL_TRANSPOSITION_KERNEL(double2);
52
+ size_t len = strlen(kernel);
53
+ cl_int err;
54
+ cl_context c_context = queue.get_context().get();
55
+ cl_program program = clCreateProgramWithSource(c_context, 1, &kernel, &len, &err);
56
+ clBuildProgram(program, 1, &queue.get_device().get(), NULL, NULL, NULL);
57
+ cl_kernel c_kernel = clCreateKernel(program, "transpose", &err);
58
+ size_t width = std::is_same < L1, ublas::basic_row_major<>>::value ? m.size2() : m.size1();
59
+ size_t height = std::is_same < L1, ublas::basic_row_major<>>::value ? m.size1() : m.size2();
60
+ size_t global_size[2] = { width , height };
61
+ clSetKernelArg(c_kernel, 0, sizeof(T*), &m.begin().get_buffer().get());
62
+ clSetKernelArg(c_kernel, 1, sizeof(T*), &result.begin().get_buffer().get());
63
+ clSetKernelArg(c_kernel, 2, sizeof(unsigned int), &width);
64
+ clSetKernelArg(c_kernel, 3, sizeof(unsigned int), &height);
65
+ cl_command_queue c_queue = queue.get();
66
+ cl_event event = NULL;
67
+ clEnqueueNDRangeKernel(c_queue, c_kernel, 2, NULL, global_size, NULL, 0, NULL, &event);
68
+ clWaitForEvents(1, &event);
69
+ }
70
+
71
+ template<class T, class L1, class L2, class A>
72
+ typename std::enable_if<is_numeric<T>::value>::type
73
+ change_layout(ublas::matrix<T, L1, A> const &m,
74
+ ublas::matrix<T, L2, A> &result,
75
+ compute::command_queue& queue)
76
+ {
77
+ ublas::matrix<T, L1, opencl::storage> mdev(m, queue);
78
+ ublas::matrix<T, L2, opencl::storage> rdev(result.size1(), result.size2(), queue.get_context());
79
+ change_layout(mdev, rdev, queue);
80
+ rdev.to_host(result, queue);
81
+ }
82
+
83
+ template<class T, class L>
84
+ typename std::enable_if<is_numeric<T>::value>::type
85
+ trans(ublas::matrix<T, L, opencl::storage> const &m,
86
+ ublas::matrix<T, L, opencl::storage> &result,
87
+ compute::command_queue& queue)
88
+ {
89
+ assert(m.size1() == result.size2() && m.size2() == result.size1());
90
+ assert(m.device() == result.device() && m.device() == queue.get_device());
91
+ char const *kernel;
92
+ if (std::is_same<T, float>::value)
93
+ kernel = OPENCL_TRANSPOSITION_KERNEL(float);
94
+ else if (std::is_same<T, double>::value)
95
+ kernel = OPENCL_TRANSPOSITION_KERNEL(double);
96
+ else if (std::is_same<T, std::complex<float>>::value)
97
+ kernel = OPENCL_TRANSPOSITION_KERNEL(float2);
98
+ else if (std::is_same<T, std::complex<double>>::value)
99
+ kernel = OPENCL_TRANSPOSITION_KERNEL(double2);
100
+ size_t len = strlen(kernel);
101
+ cl_int err;
102
+ cl_context c_context = queue.get_context().get();
103
+ cl_program program = clCreateProgramWithSource(c_context, 1, &kernel, &len, &err);
104
+ clBuildProgram(program, 1, &queue.get_device().get(), NULL, NULL, NULL);
105
+ cl_kernel c_kernel = clCreateKernel(program, "transpose", &err);
106
+ size_t width = std::is_same <L, ublas::basic_row_major<>>::value ? m.size2() : m.size1();
107
+ size_t height = std::is_same <L, ublas::basic_row_major<>>::value ? m.size1() : m.size2();
108
+ size_t global_size[2] = { width , height };
109
+ clSetKernelArg(c_kernel, 0, sizeof(T*), &m.begin().get_buffer().get());
110
+ clSetKernelArg(c_kernel, 1, sizeof(T*), &result.begin().get_buffer().get());
111
+ clSetKernelArg(c_kernel, 2, sizeof(unsigned int), &width);
112
+ clSetKernelArg(c_kernel, 3, sizeof(unsigned int), &height);
113
+ cl_command_queue c_queue = queue.get();
114
+ cl_event event = NULL;
115
+ clEnqueueNDRangeKernel(c_queue, c_kernel, 2, NULL, global_size, NULL, 0, NULL, &event);
116
+ clWaitForEvents(1, &event);
117
+ }
118
+
119
+ template<class T, class L, class A>
120
+ typename std::enable_if<is_numeric<T>::value>::type
121
+ trans(ublas::matrix<T, L, A> const &m,
122
+ ublas::matrix<T, L, A> &result,
123
+ compute::command_queue& queue)
124
+ {
125
+ ublas::matrix<T, L, opencl::storage> mdev(m, queue);
126
+ ublas::matrix<T, L, opencl::storage> rdev(result.size1(), result.size2(), queue.get_context());
127
+ trans(mdev, rdev, queue);
128
+ rdev.to_host(result, queue);
129
+ }
130
+
131
+ template<class T, class L, class A>
132
+ typename std::enable_if<is_numeric<T>::value, ublas::matrix<T, L, A>>::type
133
+ trans(ublas::matrix<T, L, A>& m, compute::command_queue& queue)
134
+ {
135
+ ublas::matrix<T, L, A> result(m.size2(), m.size1());
136
+ trans(m, result, queue);
137
+ return result;
138
+ }
139
+
140
+ }}}}
141
+
142
+ #endif
@@ -0,0 +1,90 @@
1
+ // Boost.uBLAS
2
+ //
3
+ // Copyright (c) 2018 Fady Essam
4
+ // Copyright (c) 2018 Stefan Seefeld
5
+ //
6
+ // Distributed under the Boost Software License, Version 1.0.
7
+ // (See accompanying file LICENSE_1_0.txt or
8
+ // copy at http://www.boost.org/LICENSE_1_0.txt)
9
+
10
+ #ifndef boost_numeric_ublas_opencl_vector_hpp_
11
+ #define boost_numeric_ublas_opencl_vector_hpp_
12
+
13
+ #include <boost/numeric/ublas/opencl/library.hpp>
14
+ #include <boost/numeric/ublas/functional.hpp>
15
+ #include <boost/compute/core.hpp>
16
+ #include <boost/compute/algorithm.hpp>
17
+ #include <boost/compute/buffer.hpp>
18
+ #include <boost/compute/container/vector.hpp>
19
+
20
+ namespace boost { namespace numeric { namespace ublas { namespace opencl {
21
+
22
+ class storage;
23
+
24
+ namespace compute = boost::compute;
25
+
26
+ } // namespace opencl
27
+
28
+ template <class T>
29
+ class vector<T, opencl::storage> : public boost::compute::vector<T>
30
+ {
31
+ typedef std::size_t size_type;
32
+ public:
33
+ vector() : compute::vector<T>() {}
34
+ vector(size_type size, compute::context context)
35
+ : compute::vector<T>(size, context)
36
+ { device_ = context.get_device();}
37
+ vector(size_type size, T value, compute::command_queue queue)
38
+ : compute::vector<T>(size, value, queue.get_context())
39
+ {
40
+ queue.finish();
41
+ device_ = queue.get_device();
42
+ }
43
+
44
+ template <typename A>
45
+ vector(vector<T, A> const &v, compute::command_queue &queue)
46
+ : vector(v.size(), queue.get_context())
47
+ {
48
+ this->from_host(v, queue);
49
+ }
50
+
51
+
52
+ const compute::device device() const { return device_;}
53
+ compute::device device() { return device_;}
54
+
55
+ template<class A>
56
+ void from_host(ublas::vector<T, A> const &v, compute::command_queue & queue)
57
+ {
58
+ assert(this->device() == queue.get_device());
59
+ compute::copy(v.begin(),
60
+ v.end(),
61
+ this->begin(),
62
+ queue);
63
+ queue.finish();
64
+ }
65
+
66
+ template<class A>
67
+ void to_host(ublas::vector<T, A>& v, compute::command_queue& queue) const
68
+ {
69
+ assert(this->device() == queue.get_device());
70
+ compute::copy(this->begin(),
71
+ this->end(),
72
+ v.begin(),
73
+ queue);
74
+ queue.finish();
75
+ }
76
+
77
+ void fill(T value, compute::command_queue & queue)
78
+ {
79
+ assert(this->device() == queue.get_device());
80
+ compute::fill(this->begin(), this->end(), value, queue);
81
+ queue.finish();
82
+ }
83
+
84
+ private:
85
+ compute::device device_;
86
+ };
87
+
88
+ }}}
89
+
90
+ #endif
@@ -0,0 +1,16 @@
1
+ //
2
+ // Copyright (c) 2018 Stefan Seefeld
3
+ //
4
+ // Distributed under the Boost Software License, Version 1.0.
5
+ // (See accompanying file LICENSE_1_0.txt or
6
+ // copy at http://www.boost.org/LICENSE_1_0.txt)
7
+
8
+ #ifndef boost_numeric_ublas_opencl_hpp_
9
+ #define boost_numeric_ublas_opencl_hpp_
10
+
11
+ #include <boost/numeric/ublas/opencl/library.hpp>
12
+ #include <boost/numeric/ublas/opencl/vector.hpp>
13
+ #include <boost/numeric/ublas/opencl/matrix.hpp>
14
+ #include <boost/numeric/ublas/opencl/operations.hpp>
15
+
16
+ #endif
@@ -0,0 +1,318 @@
1
+ /**
2
+ * -*- c++ -*-
3
+ *
4
+ * \file begin.hpp
5
+ *
6
+ * \brief The \c begin operation.
7
+ *
8
+ * Copyright (c) 2009, Marco Guazzone
9
+ *
10
+ * Distributed under the Boost Software License, Version 1.0. (See
11
+ * accompanying file LICENSE_1_0.txt or copy at
12
+ * http://www.boost.org/LICENSE_1_0.txt)
13
+ *
14
+ * \author Marco Guazzone, marco.guazzone@gmail.com
15
+ */
16
+
17
+ #ifndef BOOST_NUMERIC_UBLAS_OPERATION_BEGIN_HPP
18
+ #define BOOST_NUMERIC_UBLAS_OPERATION_BEGIN_HPP
19
+
20
+
21
+ #include <boost/numeric/ublas/expression_types.hpp>
22
+ #include <boost/numeric/ublas/fwd.hpp>
23
+ #include <boost/numeric/ublas/traits/const_iterator_type.hpp>
24
+ #include <boost/numeric/ublas/traits/iterator_type.hpp>
25
+
26
+
27
+ namespace boost { namespace numeric { namespace ublas {
28
+
29
+ namespace detail {
30
+
31
+ /**
32
+ * \brief Auxiliary class for implementing the \c begin operation.
33
+ * \tparam CategoryT The expression category type (e.g., vector_tag).
34
+ * \tparam TagT The dimension type tag (e.g., tag::major).
35
+ * \tparam OrientationT The orientation category type (e.g., row_major_tag).
36
+ */
37
+ template <typename CategoryT, typename TagT=void, typename OrientationT=void>
38
+ struct begin_impl;
39
+
40
+
41
+ /// \brief Specialization of \c begin_impl for iterating vector expressions.
42
+ template <>
43
+ struct begin_impl<vector_tag,void,void>
44
+ {
45
+ /**
46
+ * \brief Return an iterator to the first element of the given vector
47
+ * expression.
48
+ * \tparam ExprT A model of VectorExpression type.
49
+ * \param e A vector expression.
50
+ * \return An iterator over the given vector expression.
51
+ */
52
+ template <typename ExprT>
53
+ static typename ExprT::iterator apply(ExprT& e)
54
+ {
55
+ return e.begin();
56
+ }
57
+
58
+
59
+ /**
60
+ * \brief Return a const iterator to the first element of the given vector
61
+ * expression.
62
+ * \tparam ExprT A model of VectorExpression type.
63
+ * \param e A vector expression.
64
+ * \return A const iterator to the first element of the given vector
65
+ * expression.
66
+ */
67
+ template <typename ExprT>
68
+ static typename ExprT::const_iterator apply(ExprT const& e)
69
+ {
70
+ return e.begin();
71
+ }
72
+ };
73
+
74
+
75
+ /// \brief Specialization of \c begin_impl for iterating matrix expressions with
76
+ /// a row-major orientation over the major dimension.
77
+ template <>
78
+ struct begin_impl<matrix_tag,tag::major,row_major_tag>
79
+ {
80
+ /**
81
+ * \brief Return an iterator to the first element of the given row-major
82
+ * matrix expression over the major dimension.
83
+ * \tparam ExprT A model of MatrixExpression type.
84
+ * \param e A matrix expression.
85
+ * \return An iterator over the major dimension of the given matrix
86
+ * expression.
87
+ */
88
+ template <typename ExprT>
89
+ static typename ExprT::iterator1 apply(ExprT& e)
90
+ {
91
+ return e.begin1();
92
+ }
93
+
94
+
95
+ /**
96
+ * \brief Return a const iterator to the first element of the given
97
+ * row-major matrix expression over the major dimension.
98
+ * \tparam ExprT A model of MatrixExpression type.
99
+ * \param e A matrix expression.
100
+ * \return A const iterator over the major dimension of the given matrix
101
+ * expression.
102
+ */
103
+ template <typename ExprT>
104
+ static typename ExprT::const_iterator1 apply(ExprT const& e)
105
+ {
106
+ return e.begin1();
107
+ }
108
+ };
109
+
110
+
111
+ /// \brief Specialization of \c begin_impl for iterating matrix expressions with
112
+ /// a column-major orientation over the major dimension.
113
+ template <>
114
+ struct begin_impl<matrix_tag,tag::major,column_major_tag>
115
+ {
116
+ /**
117
+ * \brief Return an iterator to the first element of the given column-major
118
+ * matrix expression over the major dimension.
119
+ * \tparam ExprT A model of MatrixExpression type.
120
+ * \param e A matrix expression.
121
+ * \return An iterator over the major dimension of the given matrix
122
+ * expression.
123
+ */
124
+ template <typename ExprT>
125
+ static typename ExprT::iterator2 apply(ExprT& e)
126
+ {
127
+ return e.begin2();
128
+ }
129
+
130
+
131
+ /**
132
+ * \brief Return a const iterator to the first element of the given
133
+ * column-major matrix expression over the major dimension.
134
+ * \tparam ExprT A model of MatrixExpression type.
135
+ * \param e A matrix expression.
136
+ * \return A const iterator over the major dimension of the given matrix
137
+ * expression.
138
+ */
139
+ template <typename ExprT>
140
+ static typename ExprT::const_iterator2 apply(ExprT const& e)
141
+ {
142
+ return e.begin2();
143
+ }
144
+ };
145
+
146
+
147
+ /// \brief Specialization of \c begin_impl for iterating matrix expressions with
148
+ /// a row-major orientation over the minor dimension.
149
+ template <>
150
+ struct begin_impl<matrix_tag,tag::minor,row_major_tag>
151
+ {
152
+ /**
153
+ * \brief Return an iterator to the first element of the given row-major
154
+ * matrix expression over the minor dimension.
155
+ * \tparam ExprT A model of MatrixExpression type.
156
+ * \param e A matrix expression.
157
+ * \return An iterator over the minor dimension of the given matrix
158
+ * expression.
159
+ */
160
+ template <typename ExprT>
161
+ static typename ExprT::iterator2 apply(ExprT& e)
162
+ {
163
+ return e.begin2();
164
+ }
165
+
166
+
167
+ /**
168
+ * \brief Return a const iterator to the first element of the given
169
+ * row-major matrix expression over the minor dimension.
170
+ * \tparam ExprT A model of MatrixExpression type.
171
+ * \param e A matrix expression.
172
+ * \return A const iterator over the minor dimension of the given matrix
173
+ * expression.
174
+ */
175
+ template <typename ExprT>
176
+ static typename ExprT::const_iterator2 apply(ExprT const& e)
177
+ {
178
+ return e.begin2();
179
+ }
180
+ };
181
+
182
+
183
+
184
+ /// \brief Specialization of \c begin_impl for iterating matrix expressions with
185
+ /// a column-major orientation over the minor dimension.
186
+ template <>
187
+ struct begin_impl<matrix_tag,tag::minor,column_major_tag>
188
+ {
189
+ /**
190
+ * \brief Return an iterator to the first element of the given column-major
191
+ * matrix expression over the minor dimension.
192
+ * \tparam ExprT A model of MatrixExpression type.
193
+ * \param e A matrix expression.
194
+ * \return An iterator over the minor dimension of the given matrix
195
+ * expression.
196
+ */
197
+ template <typename ExprT>
198
+ static typename ExprT::iterator1 apply(ExprT& e)
199
+ {
200
+ return e.begin1();
201
+ }
202
+
203
+
204
+ /**
205
+ * \brief Return a const iterator to the first element of the given
206
+ * column-major matrix expression over the minor dimension.
207
+ * \tparam ExprT A model of MatrixExpression type.
208
+ * \param e A matrix expression.
209
+ * \return A const iterator over the minor dimension of the given matrix
210
+ * expression.
211
+ */
212
+ template <typename ExprT>
213
+ static typename ExprT::const_iterator1 apply(ExprT const& e)
214
+ {
215
+ return e.begin1();
216
+ }
217
+ };
218
+
219
+ } // Namespace detail
220
+
221
+
222
+ /**
223
+ * \brief An iterator to the first element of the given vector expression.
224
+ * \tparam ExprT A model of VectorExpression type.
225
+ * \param e A vector expression.
226
+ * \return An iterator to the first element of the given vector expression.
227
+ */
228
+ template <typename ExprT>
229
+ BOOST_UBLAS_INLINE
230
+ typename ExprT::iterator begin(vector_expression<ExprT>& e)
231
+ {
232
+ return detail::begin_impl<typename ExprT::type_category>::apply(e());
233
+ }
234
+
235
+
236
+ /**
237
+ * \brief A const iterator to the first element of the given vector expression.
238
+ * \tparam ExprT A model of VectorExpression type.
239
+ * \param e A vector expression.
240
+ * \return A const iterator to the first element of the given vector expression.
241
+ */
242
+ template <typename ExprT>
243
+ BOOST_UBLAS_INLINE
244
+ typename ExprT::const_iterator begin(vector_expression<ExprT> const& e)
245
+ {
246
+ return detail::begin_impl<typename ExprT::type_category>::apply(e());
247
+ }
248
+
249
+
250
+ /**
251
+ * \brief An iterator to the first element of the given matrix expression
252
+ * according to its orientation.
253
+ * \tparam DimTagT A dimension tag type (e.g., tag::major).
254
+ * \tparam ExprT A model of MatrixExpression type.
255
+ * \param e A matrix expression.
256
+ * \return An iterator to the first element of the given matrix expression
257
+ * according to its orientation.
258
+ */
259
+ template <typename TagT, typename ExprT>
260
+ BOOST_UBLAS_INLINE
261
+ typename iterator_type<ExprT,TagT>::type begin(matrix_expression<ExprT>& e)
262
+ {
263
+ return detail::begin_impl<typename ExprT::type_category, TagT, typename ExprT::orientation_category>::apply(e());
264
+ }
265
+
266
+
267
+ /**
268
+ * \brief A const iterator to the first element of the given matrix expression
269
+ * according to its orientation.
270
+ * \tparam TagT A dimension tag type (e.g., tag::major).
271
+ * \tparam ExprT A model of MatrixExpression type.
272
+ * \param e A matrix expression.
273
+ * \return A const iterator to the first element of the given matrix expression
274
+ * according to its orientation.
275
+ */
276
+ template <typename TagT, typename ExprT>
277
+ BOOST_UBLAS_INLINE
278
+ typename const_iterator_type<ExprT,TagT>::type begin(matrix_expression<ExprT> const& e)
279
+ {
280
+ return detail::begin_impl<typename ExprT::type_category, TagT, typename ExprT::orientation_category>::apply(e());
281
+ }
282
+
283
+
284
+ /**
285
+ * \brief An iterator to the first element over the dual dimension of the given
286
+ * iterator.
287
+ * \tparam IteratorT A model of Iterator type.
288
+ * \param it An iterator.
289
+ * \return An iterator to the first element over the dual dimension of the given
290
+ * iterator.
291
+ */
292
+ template <typename IteratorT>
293
+ BOOST_UBLAS_INLINE
294
+ typename IteratorT::dual_iterator_type begin(IteratorT& it)
295
+ {
296
+ return it.begin();
297
+ }
298
+
299
+
300
+ /**
301
+ * \brief A const iterator to the first element over the dual dimension of the
302
+ * given iterator.
303
+ * \tparam IteratorT A model of Iterator type.
304
+ * \param it An iterator.
305
+ * \return A const iterator to the first element over the dual dimension of the
306
+ * given iterator.
307
+ */
308
+ template <typename IteratorT>
309
+ BOOST_UBLAS_INLINE
310
+ typename IteratorT::dual_iterator_type begin(IteratorT const& it)
311
+ {
312
+ return it.begin();
313
+ }
314
+
315
+ }}} // Namespace boost::numeric::ublas
316
+
317
+
318
+ #endif // BOOST_NUMERIC_UBLAS_OPERATION_BEGIN_HPP
@@ -0,0 +1,41 @@
1
+ /**
2
+ * -*- c++ -*-
3
+ *
4
+ * \file c_array.hpp
5
+ *
6
+ * \brief provides specializations of matrix and vector operations for c arrays and c matrices.
7
+ *
8
+ * Copyright (c) 2009, Gunter Winkler
9
+ *
10
+ * Distributed under the Boost Software License, Version 1.0. (See
11
+ * accompanying file LICENSE_1_0.txt or copy at
12
+ * http://www.boost.org/LICENSE_1_0.txt)
13
+ *
14
+ * \author Gunter Winkler (guwi17 at gmx dot de)
15
+ */
16
+
17
+ #ifndef BOOST_NUMERIC_UBLAS_OPERATION_C_ARRAY_HPP
18
+ #define BOOST_NUMERIC_UBLAS_OPERATION_C_ARRAY_HPP
19
+
20
+ #include <boost/numeric/ublas/traits/c_array.hpp>
21
+
22
+ namespace boost { namespace numeric { namespace ublas {
23
+
24
+ namespace detail {
25
+
26
+
27
+
28
+ } // namespace boost::numeric::ublas::detail
29
+
30
+
31
+ template <typename T>
32
+ BOOST_UBLAS_INLINE
33
+ typename ExprT::const_iterator begin(vector_expression<ExprT> const& e)
34
+ {
35
+ return detail::begin_impl<typename ExprT::type_category>::apply(e());
36
+ }
37
+
38
+
39
+ }}} // Namespace boost::numeric::ublas
40
+
41
+ #endif