1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
// Copyright 2008-2024 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)
#if __cplusplus <= 199711L
#include <iostream>
int main()
{
std::cout << "Test not applicable due to lack of C++11 support in the compiler" << std::endl;
return 0;
}
#else
#ifdef BOOST_QVM_TEST_SINGLE_HEADER
# include BOOST_QVM_TEST_SINGLE_HEADER
#else
# include <boost/qvm/mat_operations.hpp>
#endif
#include <boost/qvm/mat_traits_array.hpp>
#include <boost/core/lightweight_test.hpp>
template <class T,class U>
struct same_type;
template <class T>
struct
same_type<T,T>
{
};
int
main()
{
using namespace boost::qvm;
BOOST_QVM_STATIC_ASSERT((!is_mat<std::array<int,3>>::value));
BOOST_QVM_STATIC_ASSERT((!is_mat<std::array<std::array<std::array<int,3>,3>,3>>::value));
BOOST_QVM_STATIC_ASSERT((is_mat<std::array<std::array<int,3>,4>>::value));
BOOST_QVM_STATIC_ASSERT((is_mat<std::array<std::array<int const,3>,4>>::value));
BOOST_QVM_STATIC_ASSERT((is_mat<std::array<std::array<int,3>,4> const>::value));
BOOST_QVM_STATIC_ASSERT((is_mat<std::array<std::array<int const,3>,4> const>::value));
BOOST_QVM_STATIC_ASSERT((mat_traits<std::array<std::array<int,3>,4>>::rows==3));
BOOST_QVM_STATIC_ASSERT((mat_traits<std::array<std::array<int,3>,4>>::cols==4));
same_type<mat_traits<std::array<std::array<int,3>,4>>::scalar_type,int>();
same_type< mat<int,3,3>, deduce_mat<std::array<std::array<int,3>,3>>::type >();
same_type< mat<int const,3,3>, deduce_mat<std::array<std::array<int const,3>,3>>::type >();
same_type< mat<int,3,3>, deduce_mat<std::array<std::array<int,3>,3> const>::type >();
same_type< mat<int const,3,3>, deduce_mat<std::array<std::array<int const,3>,3> const>::type >();
std::array<std::array<int,3>,3> arr1 = {std::array<int,3>{00,01,02},std::array<int,3>{10,11,12},std::array<int,3>{20,21,22}};
std::array<std::array<int const,3>,3> arr2 = {std::array<int const,3>{00,01,02},std::array<int const,3>{10,11,12},std::array<int const,3>{20,21,22}};
std::array<std::array<int,3>,3> const arr3 = {std::array<int,3>{00,01,02},std::array<int,3>{10,11,12},std::array<int,3>{20,21,22}};
std::array<std::array<int const,3>,3> const arr4 = {std::array<int const,3>{00,01,02},std::array<int const,3>{10,11,12},std::array<int const,3>{20,21,22}};
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<0,0>(arr1)==00));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<0,1>(arr1)==01));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<0,2>(arr1)==02));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<1,0>(arr1)==10));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<1,1>(arr1)==11));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<1,2>(arr1)==12));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<2,0>(arr1)==20));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<2,1>(arr1)==21));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element<2,2>(arr1)==22));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<0,0>(arr2)==00));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<0,1>(arr2)==01));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<0,2>(arr2)==02));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<1,0>(arr2)==10));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<1,1>(arr2)==11));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<1,2>(arr2)==12));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<2,0>(arr2)==20));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<2,1>(arr2)==21));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element<2,2>(arr2)==22));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<0,0>(arr3)==00));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<0,1>(arr3)==01));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<0,2>(arr3)==02));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<1,0>(arr3)==10));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<1,1>(arr3)==11));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<1,2>(arr3)==12));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<2,0>(arr3)==20));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<2,1>(arr3)==21));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element<2,2>(arr3)==22));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<0,0>(arr4)==00));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<0,1>(arr4)==01));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<0,2>(arr4)==02));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<1,0>(arr4)==10));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<1,1>(arr4)==11));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<1,2>(arr4)==12));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<2,0>(arr4)==20));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<2,1>(arr4)==21));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element<2,2>(arr4)==22));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(0,0,arr1)==00));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(0,1,arr1)==01));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(0,2,arr1)==02));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(1,0,arr1)==10));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(1,1,arr1)==11));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(1,2,arr1)==12));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(2,0,arr1)==20));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(2,1,arr1)==21));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3>>::read_element_idx(2,2,arr1)==22));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(0,0,arr2)==00));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(0,1,arr2)==01));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(0,2,arr2)==02));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(1,0,arr2)==10));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(1,1,arr2)==11));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(1,2,arr2)==12));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(2,0,arr2)==20));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(2,1,arr2)==21));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3>>::read_element_idx(2,2,arr2)==22));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(0,0,arr3)==00));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(0,1,arr3)==01));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(0,2,arr3)==02));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(1,0,arr3)==10));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(1,1,arr3)==11));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(1,2,arr3)==12));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(2,0,arr3)==20));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(2,1,arr3)==21));
BOOST_TEST((mat_traits<std::array<std::array<int,3>,3> const>::read_element_idx(2,2,arr3)==22));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(0,0,arr4)==00));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(0,1,arr4)==01));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(0,2,arr4)==02));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(1,0,arr4)==10));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(1,1,arr4)==11));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(1,2,arr4)==12));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(2,0,arr4)==20));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(2,1,arr4)==21));
BOOST_TEST((mat_traits<std::array<std::array<int const,3>,3> const>::read_element_idx(2,2,arr4)==22));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<0,0>(arr1)==&arr1[0][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<0,1>(arr1)==&arr1[0][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<0,2>(arr1)==&arr1[0][2]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<1,0>(arr1)==&arr1[1][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<1,1>(arr1)==&arr1[1][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<1,2>(arr1)==&arr1[1][2]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<2,0>(arr1)==&arr1[2][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<2,1>(arr1)==&arr1[2][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element<2,2>(arr1)==&arr1[2][2]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(0,0,arr1)==&arr1[0][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(0,1,arr1)==&arr1[0][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(0,2,arr1)==&arr1[0][2]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(1,0,arr1)==&arr1[1][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(1,1,arr1)==&arr1[1][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(1,2,arr1)==&arr1[1][2]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(2,0,arr1)==&arr1[2][0]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(2,1,arr1)==&arr1[2][1]));
BOOST_TEST((&mat_traits<std::array<std::array<int,3>,3>>::write_element_idx(2,2,arr1)==&arr1[2][2]));
return boost::report_errors();
}
#endif
|