| |
| |
| |
| |
| |
| |
| |
| |
|
|
|
|
| #define TEST_ENABLE_TEMPORARY_TRACKING |
|
|
| #include "main.h" |
|
|
| template<typename MatrixType> struct Wrapper |
| { |
| MatrixType m_mat; |
| inline Wrapper(const MatrixType &x) : m_mat(x) {} |
| inline operator const MatrixType& () const { return m_mat; } |
| inline operator MatrixType& () { return m_mat; } |
| }; |
|
|
| template<typename MatrixType> void ctor_init1(const MatrixType& m) |
| { |
| |
| Index rows = m.rows(); |
| Index cols = m.cols(); |
|
|
| MatrixType m0 = MatrixType::Random(rows,cols); |
|
|
| VERIFY_EVALUATION_COUNT( MatrixType m1(m0), 1); |
| VERIFY_EVALUATION_COUNT( MatrixType m2(m0+m0), 1); |
| VERIFY_EVALUATION_COUNT( MatrixType m2(m0.block(0,0,rows,cols)) , 1); |
|
|
| Wrapper<MatrixType> wrapper(m0); |
| VERIFY_EVALUATION_COUNT( MatrixType m3(wrapper) , 1); |
| } |
|
|
|
|
| void test_constructor() |
| { |
| for(int i = 0; i < g_repeat; i++) { |
| CALL_SUBTEST_1( ctor_init1(Matrix<float, 1, 1>()) ); |
| CALL_SUBTEST_1( ctor_init1(Matrix4d()) ); |
| CALL_SUBTEST_1( ctor_init1(MatrixXcf(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) ); |
| CALL_SUBTEST_1( ctor_init1(MatrixXi(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) ); |
| } |
| { |
| Matrix<Index,1,1> a(123); |
| VERIFY_IS_EQUAL(a[0], 123); |
| } |
| { |
| Matrix<Index,1,1> a(123.0); |
| VERIFY_IS_EQUAL(a[0], 123); |
| } |
| { |
| Matrix<float,1,1> a(123); |
| VERIFY_IS_EQUAL(a[0], 123.f); |
| } |
| { |
| Array<Index,1,1> a(123); |
| VERIFY_IS_EQUAL(a[0], 123); |
| } |
| { |
| Array<Index,1,1> a(123.0); |
| VERIFY_IS_EQUAL(a[0], 123); |
| } |
| { |
| Array<float,1,1> a(123); |
| VERIFY_IS_EQUAL(a[0], 123.f); |
| } |
| { |
| Array<Index,3,3> a(123); |
| VERIFY_IS_EQUAL(a(4), 123); |
| } |
| { |
| Array<Index,3,3> a(123.0); |
| VERIFY_IS_EQUAL(a(4), 123); |
| } |
| { |
| Array<float,3,3> a(123); |
| VERIFY_IS_EQUAL(a(4), 123.f); |
| } |
| } |
|
|