mat_assign.hpp 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #ifndef BOOST_QVM_DETAIL_MAT_ASSIGN_HPP_INCLUDED
  2. #define BOOST_QVM_DETAIL_MAT_ASSIGN_HPP_INCLUDED
  3. // Copyright 2008-2022 Emil Dotchevski and Reverge Studios, Inc.
  4. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. #include <boost/qvm/gen/mat_assign2.hpp>
  7. #include <boost/qvm/gen/mat_assign3.hpp>
  8. #include <boost/qvm/gen/mat_assign4.hpp>
  9. namespace boost { namespace qvm {
  10. namespace
  11. qvm_detail
  12. {
  13. template <int M,int N>
  14. struct
  15. assign_mm_defined
  16. {
  17. static bool const value=false;
  18. };
  19. template <int I,int N>
  20. struct
  21. copy_matrix_elements
  22. {
  23. template <class A,class B>
  24. static
  25. BOOST_QVM_CONSTEXPR BOOST_QVM_INLINE_CRITICAL
  26. typename enable_if_c<
  27. mat_write_element_ref<A>::value,
  28. void>::type
  29. f( A & a, B const & b )
  30. {
  31. mat_traits<A>::template write_element<I/mat_traits<A>::cols,I%mat_traits<A>::cols>(a) =
  32. mat_traits<B>::template read_element<I/mat_traits<B>::cols,I%mat_traits<B>::cols>(b);
  33. copy_matrix_elements<I+1,N>::f(a,b);
  34. }
  35. template <class A,class B>
  36. static
  37. BOOST_QVM_CONSTEXPR BOOST_QVM_INLINE_CRITICAL
  38. typename enable_if_c<
  39. !mat_write_element_ref<A>::value,
  40. void>::type
  41. f( A & a, B const & b )
  42. {
  43. mat_traits<A>::template write_element<I/mat_traits<A>::cols,I%mat_traits<A>::cols>(a,
  44. mat_traits<B>::template read_element<I/mat_traits<B>::cols,I%mat_traits<B>::cols>(b));
  45. copy_matrix_elements<I+1,N>::f(a,b);
  46. }
  47. };
  48. template <int N>
  49. struct
  50. copy_matrix_elements<N,N>
  51. {
  52. template <class A,class B>
  53. static
  54. BOOST_QVM_CONSTEXPR BOOST_QVM_INLINE_CRITICAL
  55. void
  56. f( A &, B const & )
  57. {
  58. }
  59. };
  60. }
  61. template <class A,class B>
  62. BOOST_QVM_CONSTEXPR BOOST_QVM_INLINE_TRIVIAL
  63. typename enable_if_c<
  64. is_mat<A>::value && is_mat<B>::value &&
  65. mat_traits<A>::rows==mat_traits<B>::rows &&
  66. mat_traits<A>::cols==mat_traits<B>::cols &&
  67. !qvm_detail::assign_mm_defined<mat_traits<A>::rows,mat_traits<A>::cols>::value,
  68. A &>::type
  69. assign( A & a, B const & b )
  70. {
  71. qvm_detail::copy_matrix_elements<0,mat_traits<A>::rows*mat_traits<A>::cols>::f(a,b);
  72. return a;
  73. }
  74. } }
  75. #endif