1 //Copyright (c) 2008-2016 Emil Dotchevski and Reverge Studios, Inc.
2 
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)
5 
6 #include <boost/qvm/map.hpp>
7 #include <boost/qvm/mat_traits_array.hpp>
8 #include <boost/qvm/vec_operations.hpp>
9 #include <boost/qvm/mat_operations.hpp>
10 #include <boost/qvm/mat.hpp>
11 #include "test_qvm_vector.hpp"
12 #include "gold.hpp"
13 
14 namespace
15     {
16     template <int Dim>
17     void
test()18     test()
19         {
20         using namespace boost::qvm;
21         test_qvm::vector<V1,Dim-1> x(42,1);
22         float r1[Dim][Dim];
23         test_qvm::translation(r1,x.a);
24         float r2[Dim][Dim];
25         assign(r2,translation_mat(x));
26         BOOST_QVM_TEST_EQ(r1,r2);
27         test_qvm::scalar_multiply_v(x.b,x.a,2.0f);
28         col<Dim-1>(del_row<Dim-1>(translation_mat(x))) *= 2;
29         BOOST_QVM_TEST_EQ(x.a,x.b);
30         translation_mat(x) + translation_mat(x);
31         -translation_mat(x);
32         }
33     }
34 
35 int
main()36 main()
37     {
38     test<3>();
39     test<4>();
40     test<5>();
41     return boost::report_errors();
42     }
43