]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/qvm/test/plus_mm_test.cpp
1 // Copyright 2008-2022 Emil Dotchevski and Reverge Studios, Inc.
3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 #ifdef BOOST_QVM_TEST_SINGLE_HEADER
7 # include BOOST_QVM_TEST_SINGLE_HEADER
9 # include <boost/qvm/mat_operations.hpp>
10 # include <boost/qvm/mat.hpp>
13 #include "test_qvm_matrix.hpp"
18 template <class T
,class U
> struct same_type_tester
;
19 template <class T
> struct same_type_tester
<T
,T
> { };
20 template <class T
,class U
> void test_same_type( T
, U
) { same_type_tester
<T
,U
>(); }
22 template <int Rows
,int Cols
>
26 using namespace boost::qvm::sfinae
;
27 test_qvm::matrix
<M1
,Rows
,Cols
> const x(42,2);
29 test_qvm::matrix
<M1
,Rows
,Cols
> const y(42,1);
30 test_same_type(x
,x
+y
);
31 test_qvm::matrix
<M1
,Rows
,Cols
> r
=x
+y
;
32 test_qvm::add_m(r
.b
,x
.b
,y
.b
);
33 BOOST_QVM_TEST_EQ(r
.a
,r
.b
);
36 test_qvm::matrix
<M1
,Rows
,Cols
> const y(42,1);
37 test_qvm::matrix
<M2
,Rows
,Cols
> r
=mref(x
)+y
;
38 test_qvm::add_m(r
.b
,x
.b
,y
.b
);
39 BOOST_QVM_TEST_EQ(r
.a
,r
.b
);
42 test_qvm::matrix
<M1
,Rows
,Cols
> const y(42,1);
43 test_qvm::matrix
<M2
,Rows
,Cols
> r
=x
+mref(y
);
44 test_qvm::add_m(r
.b
,x
.b
,y
.b
);
45 BOOST_QVM_TEST_EQ(r
.a
,r
.b
);
65 return boost::report_errors();