//Copyright (c) 2008-2016 Emil Dotchevski and Reverge Studios, Inc. //Distributed under the Boost Software License, Version 1.0. (See accompanying //file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifdef BOOST_QVM_TEST_SINGLE_HEADER # include BOOST_QVM_TEST_SINGLE_HEADER #else # include # include # include # include #endif #include #include "test_qvm_vector.hpp" #include "gold.hpp" namespace { template void test() { using namespace boost::qvm; test_qvm::vector x(42,1); float r1[Dim][Dim]; test_qvm::translation(r1,x.a); float r2[Dim][Dim]; assign(r2,translation_mat(x)); BOOST_QVM_TEST_EQ(r1,r2); test_qvm::scalar_multiply_v(x.b,x.a,2.0f); col(del_row(translation_mat(x))) *= 2; BOOST_QVM_TEST_EQ(x.a,x.b); translation_mat(x) + translation_mat(x); -translation_mat(x); } } int main() { test<3>(); test<4>(); test<5>(); return boost::report_errors(); }