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,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
|