| // This file is part of Eigen, a lightweight C++ template library |
| // for linear algebra. |
| // |
| // Copyright (C) 2019 David Tellenbach <david.tellenbach@tellnotes.org> |
| // |
| // This Source Code Form is subject to the terms of the Mozilla |
| // Public License v. 2.0. If a copy of the MPL was not distributed |
| // with this file, You can obtain one at http://mozilla.org/MPL/2.0/. |
| |
| #include "main.h" |
| |
| #define VERIFY_IMPLICIT_CONVERSION_3(DIAGTYPE, V0, V1, V2) \ |
| DIAGTYPE d(V0, V1, V2); \ |
| DIAGTYPE::DenseMatrixType Dense = d.toDenseMatrix(); \ |
| VERIFY_IS_APPROX(Dense(0, 0), (Scalar)V0); \ |
| VERIFY_IS_APPROX(Dense(1, 1), (Scalar)V1); \ |
| VERIFY_IS_APPROX(Dense(2, 2), (Scalar)V2); |
| |
| #define VERIFY_IMPLICIT_CONVERSION_4(DIAGTYPE, V0, V1, V2, V3) \ |
| DIAGTYPE d(V0, V1, V2, V3); \ |
| DIAGTYPE::DenseMatrixType Dense = d.toDenseMatrix(); \ |
| VERIFY_IS_APPROX(Dense(0, 0), (Scalar)V0); \ |
| VERIFY_IS_APPROX(Dense(1, 1), (Scalar)V1); \ |
| VERIFY_IS_APPROX(Dense(2, 2), (Scalar)V2); \ |
| VERIFY_IS_APPROX(Dense(3, 3), (Scalar)V3); |
| |
| #define VERIFY_IMPLICIT_CONVERSION_5(DIAGTYPE, V0, V1, V2, V3, V4) \ |
| DIAGTYPE d(V0, V1, V2, V3, V4); \ |
| DIAGTYPE::DenseMatrixType Dense = d.toDenseMatrix(); \ |
| VERIFY_IS_APPROX(Dense(0, 0), (Scalar)V0); \ |
| VERIFY_IS_APPROX(Dense(1, 1), (Scalar)V1); \ |
| VERIFY_IS_APPROX(Dense(2, 2), (Scalar)V2); \ |
| VERIFY_IS_APPROX(Dense(3, 3), (Scalar)V3); \ |
| VERIFY_IS_APPROX(Dense(4, 4), (Scalar)V4); |
| |
| template <typename Scalar> |
| void constructorTest() { |
| typedef DiagonalMatrix<Scalar, 0> DiagonalMatrix0; |
| typedef DiagonalMatrix<Scalar, 3> DiagonalMatrix3; |
| typedef DiagonalMatrix<Scalar, 4> DiagonalMatrix4; |
| typedef DiagonalMatrix<Scalar, Dynamic> DiagonalMatrixX; |
| |
| Scalar raw[7]; |
| for (int k = 0; k < 7; ++k) raw[k] = internal::random<Scalar>(); |
| |
| // Fixed-sized matrices |
| { |
| DiagonalMatrix0 a{{}}; |
| VERIFY(a.rows() == 0); |
| VERIFY(a.cols() == 0); |
| typename DiagonalMatrix0::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrix3 a{{raw[0], raw[1], raw[2]}}; |
| VERIFY(a.rows() == 3); |
| VERIFY(a.cols() == 3); |
| typename DiagonalMatrix3::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrix4 a{{raw[0], raw[1], raw[2], raw[3]}}; |
| VERIFY(a.rows() == 4); |
| VERIFY(a.cols() == 4); |
| typename DiagonalMatrix4::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| |
| // dynamically sized matrices |
| { |
| DiagonalMatrixX a{{}}; |
| VERIFY(a.rows() == 0); |
| VERIFY(a.rows() == 0); |
| typename DiagonalMatrixX::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrixX a{{raw[0], raw[1], raw[2], raw[3], raw[4], raw[5], raw[6]}}; |
| VERIFY(a.rows() == 7); |
| VERIFY(a.rows() == 7); |
| typename DiagonalMatrixX::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| } |
| |
| template <> |
| void constructorTest<float>() { |
| typedef float Scalar; |
| |
| typedef DiagonalMatrix<Scalar, 0> DiagonalMatrix0; |
| typedef DiagonalMatrix<Scalar, 3> DiagonalMatrix3; |
| typedef DiagonalMatrix<Scalar, 4> DiagonalMatrix4; |
| typedef DiagonalMatrix<Scalar, 5> DiagonalMatrix5; |
| typedef DiagonalMatrix<Scalar, Dynamic> DiagonalMatrixX; |
| |
| Scalar raw[7]; |
| for (int k = 0; k < 7; ++k) raw[k] = internal::random<Scalar>(); |
| |
| // Fixed-sized matrices |
| { |
| DiagonalMatrix0 a{{}}; |
| VERIFY(a.rows() == 0); |
| VERIFY(a.cols() == 0); |
| typename DiagonalMatrix0::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrix3 a{{raw[0], raw[1], raw[2]}}; |
| VERIFY(a.rows() == 3); |
| VERIFY(a.cols() == 3); |
| typename DiagonalMatrix3::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrix4 a{{raw[0], raw[1], raw[2], raw[3]}}; |
| VERIFY(a.rows() == 4); |
| VERIFY(a.cols() == 4); |
| typename DiagonalMatrix4::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| |
| // dynamically sized matrices |
| { |
| DiagonalMatrixX a{{}}; |
| VERIFY(a.rows() == 0); |
| VERIFY(a.rows() == 0); |
| typename DiagonalMatrixX::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { |
| DiagonalMatrixX a{{raw[0], raw[1], raw[2], raw[3], raw[4], raw[5], raw[6]}}; |
| VERIFY(a.rows() == 7); |
| VERIFY(a.rows() == 7); |
| typename DiagonalMatrixX::DenseMatrixType m = a.toDenseMatrix(); |
| for (Index k = 0; k < a.rows(); ++k) VERIFY(m(k, k) == raw[k]); |
| } |
| { VERIFY_IMPLICIT_CONVERSION_3(DiagonalMatrix3, 1.2647, 2.56f, -3); } |
| { VERIFY_IMPLICIT_CONVERSION_4(DiagonalMatrix4, 1.2647, 2.56f, -3, 3.23f); } |
| { VERIFY_IMPLICIT_CONVERSION_5(DiagonalMatrix5, 1.2647, 2.56f, -3, 3.23f, 2); } |
| } |
| |
| EIGEN_DECLARE_TEST(diagonal_matrix_variadic_ctor) { |
| CALL_SUBTEST_2(constructorTest<unsigned char>()); |
| CALL_SUBTEST_2(constructorTest<float>()); |
| CALL_SUBTEST_2(constructorTest<Index>()); |
| CALL_SUBTEST_2(constructorTest<int>()); |
| CALL_SUBTEST_2(constructorTest<long int>()); |
| CALL_SUBTEST_2(constructorTest<std::ptrdiff_t>()); |
| CALL_SUBTEST_2(constructorTest<std::complex<double>>()); |
| } |