//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) #include #include #include #include "test_qvm_quaternion.hpp" #include "test_qvm_matrix.hpp" #include "gold.hpp" namespace { void test() { using namespace boost::qvm; for( float r=0; r<6.28f; r+=0.5f ) { test_qvm::quaternion q1=rotz_quat(r); test_qvm::matrix m1=convert_to< test_qvm::matrix >(q1); test_qvm::rotation_z(m1.b,r); BOOST_QVM_TEST_CLOSE(m1.a,m1.b,0.000001f); test_qvm::quaternion q2(42,1); set_rotz(q2,r); test_qvm::matrix m2=convert_to< test_qvm::matrix >(q2); test_qvm::rotation_z(m2.b,r); BOOST_QVM_TEST_CLOSE(m2.a,m2.b,0.000001f); test_qvm::quaternion q3(42,1); test_qvm::quaternion r1=q3*q1; rotate_z(q3,r); BOOST_QVM_TEST_EQ(q3.a,r1.a); } rotz_quat(0.0f)+rotz_quat(0.0f); -rotz_quat(0.0f); } } int main() { test(); return boost::report_errors(); }