mirror of https://github.com/mosra/magnum.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
568 lines
20 KiB
568 lines
20 KiB
|
14 years ago
|
/*
|
||
|
|
This file is part of Magnum.
|
||
|
|
|
||
|
13 years ago
|
Copyright © 2010, 2011, 2012, 2013 Vladimír Vondruš <mosra@centrum.cz>
|
||
|
|
|
||
|
|
Permission is hereby granted, free of charge, to any person obtaining a
|
||
|
|
copy of this software and associated documentation files (the "Software"),
|
||
|
|
to deal in the Software without restriction, including without limitation
|
||
|
|
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||
|
|
and/or sell copies of the Software, and to permit persons to whom the
|
||
|
|
Software is furnished to do so, subject to the following conditions:
|
||
|
|
|
||
|
|
The above copyright notice and this permission notice shall be included
|
||
|
|
in all copies or substantial portions of the Software.
|
||
|
14 years ago
|
|
||
|
13 years ago
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||
|
|
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||
|
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||
|
|
DEALINGS IN THE SOFTWARE.
|
||
|
14 years ago
|
*/
|
||
|
|
|
||
|
14 years ago
|
#include <sstream>
|
||
|
14 years ago
|
#include <TestSuite/Tester.h>
|
||
|
14 years ago
|
#include <Utility/Configuration.h>
|
||
|
14 years ago
|
|
||
|
14 years ago
|
#include "Math/RectangularMatrix.h"
|
||
|
14 years ago
|
|
||
|
13 years ago
|
struct Mat2x3 {
|
||
|
|
float a[6];
|
||
|
|
};
|
||
|
|
|
||
|
|
namespace Magnum { namespace Math {
|
||
|
|
|
||
|
|
namespace Implementation {
|
||
|
|
|
||
|
|
template<> struct RectangularMatrixConverter<2, 3, float, Mat2x3> {
|
||
|
13 years ago
|
constexpr static RectangularMatrix<2, 3, Float> from(const Mat2x3& other) {
|
||
|
13 years ago
|
return RectangularMatrix<2, 3, Float>(
|
||
|
|
Vector<3, Float>(other.a[0], other.a[1], other.a[2]),
|
||
|
|
Vector<3, Float>(other.a[3], other.a[4], other.a[5]));
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
constexpr static Mat2x3 to(const RectangularMatrix<2, 3, Float>& other) {
|
||
|
13 years ago
|
return Mat2x3{{other[0][0], other[0][1], other[0][2],
|
||
|
|
other[1][0], other[1][1], other[1][2]}};
|
||
|
13 years ago
|
}
|
||
|
|
};
|
||
|
|
|
||
|
|
}
|
||
|
|
|
||
|
|
namespace Test {
|
||
|
14 years ago
|
|
||
|
14 years ago
|
class RectangularMatrixTest: public Corrade::TestSuite::Tester {
|
||
|
|
public:
|
||
|
|
RectangularMatrixTest();
|
||
|
|
|
||
|
13 years ago
|
void construct();
|
||
|
13 years ago
|
void constructDefault();
|
||
|
|
void constructConversion();
|
||
|
13 years ago
|
void constructFromData();
|
||
|
13 years ago
|
void constructFromDiagonal();
|
||
|
13 years ago
|
void constructCopy();
|
||
|
13 years ago
|
|
||
|
13 years ago
|
void convert();
|
||
|
14 years ago
|
void data();
|
||
|
13 years ago
|
void row();
|
||
|
14 years ago
|
|
||
|
13 years ago
|
void compare();
|
||
|
|
|
||
|
14 years ago
|
void negative();
|
||
|
|
void addSubtract();
|
||
|
|
void multiplyDivide();
|
||
|
|
void multiply();
|
||
|
13 years ago
|
void multiplyVector();
|
||
|
14 years ago
|
|
||
|
|
void transposed();
|
||
|
13 years ago
|
void diagonal();
|
||
|
14 years ago
|
|
||
|
13 years ago
|
void vector();
|
||
|
13 years ago
|
|
||
|
13 years ago
|
void subclassTypes();
|
||
|
|
void subclass();
|
||
|
|
|
||
|
14 years ago
|
void debug();
|
||
|
|
void configuration();
|
||
|
|
};
|
||
|
|
|
||
|
13 years ago
|
typedef RectangularMatrix<4, 3, Float> Matrix4x3;
|
||
|
|
typedef RectangularMatrix<3, 4, Float> Matrix3x4;
|
||
|
13 years ago
|
typedef RectangularMatrix<2, 2, Float> Matrix2x2;
|
||
|
|
typedef RectangularMatrix<2, 2, Int> Matrix2x2i;
|
||
|
13 years ago
|
typedef Vector<4, Float> Vector4;
|
||
|
|
typedef Vector<3, Float> Vector3;
|
||
|
|
typedef Vector<2, Float> Vector2;
|
||
|
13 years ago
|
|
||
|
|
typedef RectangularMatrix<4, 3, Int> Matrix4x3i;
|
||
|
|
typedef RectangularMatrix<3, 4, Int> Matrix3x4i;
|
||
|
|
typedef Vector<4, Int> Vector4i;
|
||
|
|
typedef Vector<3, Int> Vector3i;
|
||
|
13 years ago
|
typedef Vector<2, Int> Vector2i;
|
||
|
14 years ago
|
|
||
|
|
RectangularMatrixTest::RectangularMatrixTest() {
|
||
|
13 years ago
|
addTests({&RectangularMatrixTest::construct,
|
||
|
|
&RectangularMatrixTest::constructDefault,
|
||
|
|
&RectangularMatrixTest::constructConversion,
|
||
|
|
&RectangularMatrixTest::constructFromData,
|
||
|
|
&RectangularMatrixTest::constructFromDiagonal,
|
||
|
|
&RectangularMatrixTest::constructCopy,
|
||
|
13 years ago
|
|
||
|
13 years ago
|
&RectangularMatrixTest::convert,
|
||
|
13 years ago
|
&RectangularMatrixTest::data,
|
||
|
13 years ago
|
&RectangularMatrixTest::row,
|
||
|
13 years ago
|
|
||
|
|
&RectangularMatrixTest::compare,
|
||
|
|
|
||
|
|
&RectangularMatrixTest::negative,
|
||
|
|
&RectangularMatrixTest::addSubtract,
|
||
|
|
&RectangularMatrixTest::multiplyDivide,
|
||
|
|
&RectangularMatrixTest::multiply,
|
||
|
13 years ago
|
&RectangularMatrixTest::multiplyVector,
|
||
|
13 years ago
|
|
||
|
|
&RectangularMatrixTest::transposed,
|
||
|
|
&RectangularMatrixTest::diagonal,
|
||
|
|
|
||
|
13 years ago
|
&RectangularMatrixTest::vector,
|
||
|
13 years ago
|
|
||
|
13 years ago
|
&RectangularMatrixTest::subclassTypes,
|
||
|
|
&RectangularMatrixTest::subclass,
|
||
|
|
|
||
|
13 years ago
|
&RectangularMatrixTest::debug,
|
||
|
|
&RectangularMatrixTest::configuration});
|
||
|
14 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::construct() {
|
||
|
13 years ago
|
constexpr Matrix3x4 a = {Vector4(1.0f, 2.0f, 3.0f, 4.0f),
|
||
|
|
Vector4(5.0f, 6.0f, 7.0f, 8.0f),
|
||
|
|
Vector4(9.0f, 10.0f, 11.0f, 12.0f)};
|
||
|
13 years ago
|
CORRADE_COMPARE(a, Matrix3x4(Vector4(1.0f, 2.0f, 3.0f, 4.0f),
|
||
|
|
Vector4(5.0f, 6.0f, 7.0f, 8.0f),
|
||
|
|
Vector4(9.0f, 10.0f, 11.0f, 12.0f)));
|
||
|
|
}
|
||
|
|
|
||
|
|
void RectangularMatrixTest::constructDefault() {
|
||
|
|
constexpr Matrix4x3 a;
|
||
|
|
CORRADE_COMPARE(a, Matrix4x3(Vector3(0.0f, 0.0f, 0.0f),
|
||
|
|
Vector3(0.0f, 0.0f, 0.0f),
|
||
|
|
Vector3(0.0f, 0.0f, 0.0f),
|
||
|
|
Vector3(0.0f, 0.0f, 0.0f)));
|
||
|
|
}
|
||
|
|
|
||
|
|
void RectangularMatrixTest::constructConversion() {
|
||
|
13 years ago
|
constexpr Matrix2x2 a(Vector2( 1.3f, 2.7f),
|
||
|
|
Vector2(-15.0f, 7.0f));
|
||
|
13 years ago
|
#ifndef CORRADE_GCC46_COMPATIBILITY
|
||
|
13 years ago
|
constexpr /* Not constexpr under GCC < 4.7 */
|
||
|
13 years ago
|
#endif
|
||
|
13 years ago
|
Matrix2x2i b(a);
|
||
|
13 years ago
|
|
||
|
13 years ago
|
CORRADE_COMPARE(b, Matrix2x2i(Vector2i( 1, 2),
|
||
|
|
Vector2i(-15, 7)));
|
||
|
13 years ago
|
|
||
|
|
/* Implicit conversion is not allowed */
|
||
|
13 years ago
|
CORRADE_VERIFY(!(std::is_convertible<Matrix2x2, Matrix2x2i>::value));
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::constructFromData() {
|
||
|
13 years ago
|
Float m[] = {
|
||
|
14 years ago
|
3.0f, 5.0f, 8.0f, 4.0f,
|
||
|
|
4.0f, 4.0f, 7.0f, 3.0f,
|
||
|
|
7.0f, -1.0f, 8.0f, 0.0f
|
||
|
|
};
|
||
|
|
|
||
|
13 years ago
|
Matrix3x4 expected(Vector4(3.0f, 5.0f, 8.0f, 4.0f),
|
||
|
|
Vector4(4.0f, 4.0f, 7.0f, 3.0f),
|
||
|
|
Vector4(7.0f, -1.0f, 8.0f, 0.0f));
|
||
|
14 years ago
|
|
||
|
|
CORRADE_COMPARE(Matrix3x4::from(m), expected);
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::constructFromDiagonal() {
|
||
|
13 years ago
|
constexpr Vector3 diagonal(-1.0f, 5.0f, 11.0f);
|
||
|
13 years ago
|
|
||
|
13 years ago
|
constexpr auto a = Matrix3x4::fromDiagonal(diagonal);
|
||
|
13 years ago
|
Matrix3x4 expectedA(Vector4(-1.0f, 0.0f, 0.0f, 0.0f),
|
||
|
|
Vector4( 0.0f, 5.0f, 0.0f, 0.0f),
|
||
|
|
Vector4( 0.0f, 0.0f, 11.0f, 0.0f));
|
||
|
13 years ago
|
CORRADE_COMPARE(a, expectedA);
|
||
|
13 years ago
|
|
||
|
13 years ago
|
constexpr auto b = Matrix4x3::fromDiagonal(diagonal);
|
||
|
13 years ago
|
Matrix4x3 expectedB(Vector3(-1.0f, 0.0f, 0.0f),
|
||
|
|
Vector3( 0.0f, 5.0f, 0.0f),
|
||
|
|
Vector3( 0.0f, 0.0f, 11.0f),
|
||
|
|
Vector3( 0.0f, 0.0f, 0.0f));
|
||
|
13 years ago
|
CORRADE_COMPARE(b, expectedB);
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::constructCopy() {
|
||
|
|
constexpr Matrix3x4 a(Vector4(1.0f, 2.0f, 3.0f, 4.0f),
|
||
|
|
Vector4(5.0f, 6.0f, 7.0f, 8.0f),
|
||
|
|
Vector4(9.0f, 10.0f, 11.0f, 12.0f));
|
||
|
|
constexpr Matrix3x4 b(a);
|
||
|
|
CORRADE_COMPARE(b, Matrix3x4(Vector4(1.0f, 2.0f, 3.0f, 4.0f),
|
||
|
|
Vector4(5.0f, 6.0f, 7.0f, 8.0f),
|
||
|
|
Vector4(9.0f, 10.0f, 11.0f, 12.0f)));
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::convert() {
|
||
|
|
typedef RectangularMatrix<2, 3, Float> Matrix2x3;
|
||
|
13 years ago
|
constexpr Mat2x3 a{{1.5f, 2.0f, -3.5f,
|
||
|
|
2.0f, -3.1f, 0.4f}};
|
||
|
13 years ago
|
constexpr Matrix2x3 b(Vector3(1.5f, 2.0f, -3.5f),
|
||
|
|
Vector3(2.0f, -3.1f, 0.4f));
|
||
|
|
|
||
|
|
#ifndef CORRADE_GCC46_COMPATIBILITY
|
||
|
|
constexpr /* Not constexpr under GCC < 4.7 */
|
||
|
|
#endif
|
||
|
|
Matrix2x3 c(b);
|
||
|
|
CORRADE_COMPARE(c, b);
|
||
|
|
|
||
|
|
#ifndef CORRADE_GCC46_COMPATIBILITY
|
||
|
|
constexpr /* Not constexpr under GCC < 4.7 */
|
||
|
|
#endif
|
||
|
|
Mat2x3 d(b);
|
||
|
|
for(std::size_t i = 0; i != 5; ++i)
|
||
|
|
CORRADE_COMPARE(d.a[i], a.a[i]);
|
||
|
|
|
||
|
|
/* Implicit conversion is not allowed */
|
||
|
|
CORRADE_VERIFY(!(std::is_convertible<Mat2x3, Matrix2x3>::value));
|
||
|
|
CORRADE_VERIFY(!(std::is_convertible<Matrix2x3, Mat2x3>::value));
|
||
|
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::data() {
|
||
|
|
Matrix3x4 m;
|
||
|
|
Vector4 vector(4.0f, 5.0f, 6.0f, 7.0f);
|
||
|
|
|
||
|
|
m[2] = vector;
|
||
|
|
m[1][1] = 1.0f;
|
||
|
13 years ago
|
m[0][2] = 1.5f;
|
||
|
14 years ago
|
|
||
|
13 years ago
|
CORRADE_COMPARE(m[1][1], 1.0f);
|
||
|
14 years ago
|
CORRADE_COMPARE(m[0][2], 1.5f);
|
||
|
|
CORRADE_COMPARE(m[2], vector);
|
||
|
|
|
||
|
13 years ago
|
CORRADE_COMPARE(m, Matrix3x4(Vector4(0.0f, 0.0f, 1.5f, 0.0f),
|
||
|
|
Vector4(0.0f, 1.0f, 0.0f, 0.0f),
|
||
|
|
Vector4(4.0f, 5.0f, 6.0f, 7.0f)));
|
||
|
13 years ago
|
|
||
|
13 years ago
|
/* Pointer chasings, i.e. *(b.data()[1]), are not possible */
|
||
|
|
constexpr Matrix3x4 a(Vector4(3.0f, 5.0f, 8.0f, 4.0f),
|
||
|
13 years ago
|
Vector4(4.5f, 4.0f, 7.0f, 3.0f),
|
||
|
|
Vector4(7.0f, -1.7f, 8.0f, 0.0f));
|
||
|
13 years ago
|
constexpr Vector4 b = a[2];
|
||
|
|
constexpr Float c = a[1][2];
|
||
|
|
constexpr Float d = *a.data();
|
||
|
|
CORRADE_COMPARE(b, Vector4(7.0f, -1.7f, 8.0f, 0.0f));
|
||
|
|
CORRADE_COMPARE(c, 7.0f);
|
||
|
|
CORRADE_COMPARE(d, 3.0f);
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::row() {
|
||
|
|
const Matrix3x4 a(Vector4(1.0f, 2.0f, 3.0f, 4.0f),
|
||
|
|
Vector4(5.0f, 6.0f, 7.0f, 8.0f),
|
||
|
|
Vector4(9.0f, 10.0f, 11.0f, 12.0f));
|
||
|
|
|
||
|
|
CORRADE_COMPARE(a.row(1), Vector3(2.0f, 6.0f, 10.0f));
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::compare() {
|
||
|
13 years ago
|
Matrix2x2 a(Vector2(1.0f, -3.0f),
|
||
|
|
Vector2(5.0f, -10.0f));
|
||
|
|
Matrix2x2 b(Vector2(1.0f + TypeTraits<Float>::epsilon()/2, -3.0f),
|
||
|
|
Vector2(5.0f, -10.0f));
|
||
|
|
Matrix2x2 c(Vector2(1.0f, -1.0f + TypeTraits<Float>::epsilon()*2),
|
||
|
|
Vector2(5.0f, -10.0f));
|
||
|
13 years ago
|
CORRADE_VERIFY(a == b);
|
||
|
|
CORRADE_VERIFY(a != c);
|
||
|
|
|
||
|
13 years ago
|
Matrix2x2i ai(Vector2i(1, -3),
|
||
|
|
Vector2i(5, -10));
|
||
|
|
Matrix2x2i bi(Vector2i(1, -2),
|
||
|
|
Vector2i(5, -10));
|
||
|
13 years ago
|
CORRADE_VERIFY(ai == ai);
|
||
|
|
CORRADE_VERIFY(ai != bi);
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::negative() {
|
||
|
13 years ago
|
Matrix2x2 matrix(Vector2(1.0f, -3.0f),
|
||
|
|
Vector2(5.0f, -10.0f));
|
||
|
|
Matrix2x2 negated(Vector2(-1.0f, 3.0f),
|
||
|
|
Vector2(-5.0f, 10.0f));
|
||
|
13 years ago
|
CORRADE_COMPARE(-matrix, negated);
|
||
|
14 years ago
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::addSubtract() {
|
||
|
13 years ago
|
Matrix4x3 a(Vector3(0.0f, 1.0f, 3.0f),
|
||
|
|
Vector3(4.0f, 5.0f, 7.0f),
|
||
|
|
Vector3(8.0f, 9.0f, 11.0f),
|
||
|
|
Vector3(12.0f, 13.0f, 15.0f));
|
||
|
|
Matrix4x3 b(Vector3(-4.0f, 0.5f, 9.0f),
|
||
|
|
Vector3(-9.0f, 11.0f, 0.25f),
|
||
|
|
Vector3( 0.0f, -8.0f, 19.0f),
|
||
|
|
Vector3(-3.0f, -5.0f, 2.0f));
|
||
|
|
Matrix4x3 c(Vector3(-4.0f, 1.5f, 12.0f),
|
||
|
|
Vector3(-5.0f, 16.0f, 7.25f),
|
||
|
|
Vector3( 8.0f, 1.0f, 30.0f),
|
||
|
|
Vector3( 9.0f, 8.0f, 17.0f));
|
||
|
14 years ago
|
|
||
|
13 years ago
|
CORRADE_COMPARE(a + b, c);
|
||
|
|
CORRADE_COMPARE(c - b, a);
|
||
|
14 years ago
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::multiplyDivide() {
|
||
|
13 years ago
|
Matrix2x2 matrix(Vector2(1.0f, 2.0f),
|
||
|
|
Vector2(3.0f, 4.0f));
|
||
|
|
Matrix2x2 multiplied(Vector2(-1.5f, -3.0f),
|
||
|
|
Vector2(-4.5f, -6.0f));
|
||
|
14 years ago
|
|
||
|
13 years ago
|
CORRADE_COMPARE(matrix*-1.5f, multiplied);
|
||
|
|
CORRADE_COMPARE(-1.5f*matrix, multiplied);
|
||
|
|
CORRADE_COMPARE(multiplied/-1.5f, matrix);
|
||
|
14 years ago
|
|
||
|
|
/* Divide vector with number and inverse */
|
||
|
13 years ago
|
Matrix2x2 divisor(Vector2( 1.0f, 2.0f),
|
||
|
|
Vector2(-4.0f, 8.0f));
|
||
|
|
Matrix2x2 result(Vector2( 1.0f, 0.5f),
|
||
|
|
Vector2(-0.25f, 0.125f));
|
||
|
14 years ago
|
CORRADE_COMPARE(1.0f/divisor, result);
|
||
|
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::multiply() {
|
||
|
13 years ago
|
RectangularMatrix<4, 6, Int> left(
|
||
|
|
Vector<6, Int>(-5, 27, 10, 33, 0, -15),
|
||
|
|
Vector<6, Int>( 7, 56, 66, 1, 0, -24),
|
||
|
|
Vector<6, Int>( 4, 41, 4, 0, 1, -4),
|
||
|
|
Vector<6, Int>( 9, -100, 19, -49, 1, 9)
|
||
|
14 years ago
|
);
|
||
|
|
|
||
|
13 years ago
|
RectangularMatrix<5, 4, Int> right(
|
||
|
|
Vector<4, Int>(1, -7, 0, 158),
|
||
|
|
Vector<4, Int>(2, 24, -3, 40),
|
||
|
|
Vector<4, Int>(3, -15, -2, -50),
|
||
|
|
Vector<4, Int>(4, 17, -1, -284),
|
||
|
|
Vector<4, Int>(5, 30, 4, 18)
|
||
|
14 years ago
|
);
|
||
|
|
|
||
|
13 years ago
|
RectangularMatrix<5, 6, Int> expected(
|
||
|
|
Vector<6, Int>( 1368, -16165, 2550, -7716, 158, 1575),
|
||
|
|
Vector<6, Int>( 506, -2725, 2352, -1870, 37, -234),
|
||
|
|
Vector<6, Int>( -578, 4159, -1918, 2534, -52, -127),
|
||
|
|
Vector<6, Int>(-2461, 29419, -4238, 14065, -285, -3020),
|
||
|
|
Vector<6, Int>( 363, 179, 2388, -687, 22, -649)
|
||
|
14 years ago
|
);
|
||
|
|
|
||
|
|
CORRADE_COMPARE(left*right, expected);
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::multiplyVector() {
|
||
|
|
Vector4i a(-5, 27, 10, 33);
|
||
|
|
RectangularMatrix<3, 1, Int> b(1, 2, 3);
|
||
|
|
CORRADE_COMPARE(a*b, Matrix3x4i(
|
||
|
|
Vector4i( -5, 27, 10, 33),
|
||
|
|
Vector4i(-10, 54, 20, 66),
|
||
|
|
Vector4i(-15, 81, 30, 99)
|
||
|
|
));
|
||
|
|
|
||
|
|
Matrix3x4i c(Vector4i(0, 4, 8, 12),
|
||
|
|
Vector4i(1, 5, 9, 13),
|
||
|
|
Vector4i(3, 7, 11, 15));
|
||
|
|
Vector3i d(2, -2, 3);
|
||
|
|
CORRADE_COMPARE(c*d, Vector4i(7, 19, 31, 43));
|
||
|
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::transposed() {
|
||
|
13 years ago
|
Matrix4x3 original(Vector3( 0.0f, 1.0f, 3.0f),
|
||
|
|
Vector3( 4.0f, 5.0f, 7.0f),
|
||
|
|
Vector3( 8.0f, 9.0f, 11.0f),
|
||
|
|
Vector3(12.0f, 13.0f, 15.0f));
|
||
|
14 years ago
|
|
||
|
13 years ago
|
Matrix3x4 transposed(Vector4(0.0f, 4.0f, 8.0f, 12.0f),
|
||
|
|
Vector4(1.0f, 5.0f, 9.0f, 13.0f),
|
||
|
|
Vector4(3.0f, 7.0f, 11.0f, 15.0f));
|
||
|
14 years ago
|
|
||
|
|
CORRADE_COMPARE(original.transposed(), transposed);
|
||
|
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::diagonal() {
|
||
|
|
Vector3 diagonal(-1.0f, 5.0f, 11.0f);
|
||
|
|
|
||
|
13 years ago
|
constexpr Matrix4x3 a(Vector3(-1.0f, 1.0f, 3.0f),
|
||
|
|
Vector3( 4.0f, 5.0f, 7.0f),
|
||
|
|
Vector3( 8.0f, 9.0f, 11.0f),
|
||
|
|
Vector3(12.0f, 13.0f, 15.0f));
|
||
|
|
constexpr Vector3 aDiagonal = a.diagonal();
|
||
|
|
CORRADE_COMPARE(aDiagonal, diagonal);
|
||
|
|
|
||
|
|
constexpr Matrix3x4 b(Vector4(-1.0f, 4.0f, 8.0f, 12.0f),
|
||
|
|
Vector4( 1.0f, 5.0f, 9.0f, 13.0f),
|
||
|
|
Vector4( 3.0f, 7.0f, 11.0f, 15.0f));
|
||
|
|
constexpr Vector3 bDiagonal = b.diagonal();
|
||
|
|
CORRADE_COMPARE(bDiagonal, diagonal);
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
void RectangularMatrixTest::vector() {
|
||
|
|
typedef Vector<3, Int> Vector3i;
|
||
|
|
typedef RectangularMatrix<4, 3, Int> Matrix4x3i;
|
||
|
|
typedef Vector<12, Int> Vector12i;
|
||
|
13 years ago
|
|
||
|
13 years ago
|
Matrix4x3i a(Vector3i(0, 1, 2),
|
||
|
|
Vector3i(3, 4, 5),
|
||
|
|
Vector3i(6, 7, 8),
|
||
|
|
Vector3i(9, 10, 11));
|
||
|
13 years ago
|
|
||
|
13 years ago
|
Vector12i b(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11);
|
||
|
13 years ago
|
|
||
|
13 years ago
|
CORRADE_COMPARE(a.toVector(), b);
|
||
|
|
CORRADE_COMPARE(Matrix4x3i::fromVector(b), a);
|
||
|
13 years ago
|
}
|
||
|
|
|
||
|
13 years ago
|
template<std::size_t size, class T> class BasicMat: public Math::RectangularMatrix<size, size, T> {
|
||
|
|
public:
|
||
|
|
template<class ...U> BasicMat(U&&... args): Math::RectangularMatrix<size, size, T>{std::forward<U>(args)...} {}
|
||
|
|
|
||
|
|
MAGNUM_RECTANGULARMATRIX_SUBCLASS_IMPLEMENTATION(size, size, BasicMat<size, T>)
|
||
|
|
};
|
||
|
|
|
||
|
|
MAGNUM_MATRIX_OPERATOR_IMPLEMENTATION(BasicMat<size, T>)
|
||
|
|
|
||
|
|
template<class T> class BasicMat2x2: public BasicMat<2, T> {
|
||
|
|
public:
|
||
|
|
template<class ...U> BasicMat2x2(U&&... args): BasicMat<2, T>{std::forward<U>(args)...} {}
|
||
|
|
|
||
|
|
MAGNUM_RECTANGULARMATRIX_SUBCLASS_IMPLEMENTATION(2, 2, BasicMat2x2<T>)
|
||
|
|
};
|
||
|
|
|
||
|
|
MAGNUM_MATRIXn_OPERATOR_IMPLEMENTATION(2, BasicMat2x2)
|
||
|
|
|
||
|
|
typedef BasicMat2x2<Float> Mat2x2;
|
||
|
|
|
||
|
|
void RectangularMatrixTest::subclassTypes() {
|
||
|
|
Float* const data = nullptr;
|
||
|
|
const Float* const cdata = nullptr;
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(Mat2x2::from(data)), Mat2x2&>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(Mat2x2::from(cdata)), const Mat2x2&>::value));
|
||
|
13 years ago
|
CORRADE_VERIFY((std::is_same<decltype(Mat2x2::fromDiagonal({})), Mat2x2>::value));
|
||
|
13 years ago
|
|
||
|
|
/* Const operators */
|
||
|
|
const Mat2x2 c;
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(-c), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(c + c), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(c*1.0f), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(1.0f*c), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(c/1.0f), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(1.0f/c), Mat2x2>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(Vector2()*Math::RectangularMatrix<2, 1, Float>()), Mat2x2>::value));
|
||
|
|
|
||
|
|
/* Assignment operators */
|
||
|
|
Mat2x2 a;
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(a = c), Mat2x2&>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(a += c), Mat2x2&>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(a -= c), Mat2x2&>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(a *= 1.0f), Mat2x2&>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(a /= 1.0f), Mat2x2&>::value));
|
||
|
|
|
||
|
|
/* Operators on variable-sized matrix */
|
||
|
|
const BasicMat<3, Float> c2;
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(1.0f*c2), BasicMat<3, Float>>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(1.0f/c2), BasicMat<3, Float>>::value));
|
||
|
|
CORRADE_VERIFY((std::is_same<decltype(Vector3()*Math::RectangularMatrix<3, 1, Float>()), BasicMat<3, Float>>::value));
|
||
|
|
}
|
||
|
|
|
||
|
|
void RectangularMatrixTest::subclass() {
|
||
|
|
Float data[] = {1.0f, -2.0f, 3.0f, -4.5f};
|
||
|
|
CORRADE_COMPARE(Mat2x2::from(data), Mat2x2(Vector2(1.0f, -2.0f),
|
||
|
|
Vector2(3.0f, -4.5f)));
|
||
|
|
|
||
|
|
const Float cdata[] = {1.0f, -2.0f, 3.0f, -4.5f};
|
||
|
|
CORRADE_COMPARE(Mat2x2::from(cdata), Mat2x2(Vector2(1.0f, -2.0f),
|
||
|
|
Vector2(3.0f, -4.5f)));
|
||
|
|
|
||
|
13 years ago
|
CORRADE_COMPARE(Mat2x2::fromDiagonal({1.0f, -2.0f}), Mat2x2(Vector2(1.0f, 0.0f),
|
||
|
|
Vector2(0.0f, -2.0f)));
|
||
|
|
|
||
|
13 years ago
|
const Mat2x2 a(Vector2(1.0f, -3.0f),
|
||
|
|
Vector2(-3.0f, 1.0f));
|
||
|
|
CORRADE_COMPARE(-a, Mat2x2(Vector2(-1.0f, 3.0f),
|
||
|
|
Vector2(3.0f, -1.0f)));
|
||
|
|
|
||
|
|
Mat2x2 b(Vector2(-2.0f, 5.0f),
|
||
|
|
Vector2(5.0f, -2.0f));
|
||
|
|
const Mat2x2 bExpected(Vector2(-1.0f, 2.0f),
|
||
|
|
Vector2(2.0f, -1.0f));
|
||
|
|
CORRADE_COMPARE(b + a, bExpected);
|
||
|
|
|
||
|
|
Mat2x2 c(Vector2(-2.0f, 5.0f),
|
||
|
|
Vector2(5.0f, -2.0f));
|
||
|
|
const Mat2x2 cExpected(Vector2(-3.0f, 8.0f),
|
||
|
|
Vector2(8.0f, -3.0f));
|
||
|
|
CORRADE_COMPARE(c - a, cExpected);
|
||
|
|
|
||
|
|
Mat2x2 d(Vector2(-2.0f, 5.0f),
|
||
|
|
Vector2(5.0f, -2.0f));
|
||
|
|
const Mat2x2 dExpected(Vector2(-4.0f, 10.0f),
|
||
|
|
Vector2(10.0f, -4.0f));
|
||
|
|
CORRADE_COMPARE(d*2.0f, dExpected);
|
||
|
|
CORRADE_COMPARE(2.0f*d, dExpected);
|
||
|
|
|
||
|
|
Mat2x2 e(Vector2(-2.0f, 5.0f),
|
||
|
|
Vector2(5.0f, -2.0f));
|
||
|
|
CORRADE_COMPARE(e/0.5f, dExpected);
|
||
|
|
CORRADE_COMPARE(2.0f/e, Mat2x2(Vector2(-1.0f, 0.4f),
|
||
|
|
Vector2(0.4f, -1.0f)));
|
||
|
|
const Vector2 f(2.0f, 5.0f);
|
||
|
|
const Math::RectangularMatrix<2, 1, Float> g(3.0f, -1.0f);
|
||
|
|
CORRADE_COMPARE(f*g, Mat2x2(Vector2(6.0f, 15.0f),
|
||
|
|
Vector2(-2.0f, -5.0f)));
|
||
|
|
|
||
|
|
/* Operators on variable-sized matrix */
|
||
|
|
const BasicMat<1, Float> h(-2.0f);
|
||
|
|
CORRADE_COMPARE(2.0f*h, (BasicMat<1, Float>(-4.0f)));
|
||
|
|
CORRADE_COMPARE(2.0f/h, (BasicMat<1, Float>(-1.0f)));
|
||
|
|
|
||
|
|
const Math::Vector<1, Float> i(2.0f);
|
||
|
|
const Math::RectangularMatrix<1, 1, Float> j(3.0f);
|
||
|
|
CORRADE_COMPARE(i*j, (BasicMat<1, Float>(6.0f)));
|
||
|
|
}
|
||
|
|
|
||
|
14 years ago
|
void RectangularMatrixTest::debug() {
|
||
|
13 years ago
|
Matrix3x4 m(Vector4(3.0f, 5.0f, 8.0f, 4.0f),
|
||
|
|
Vector4(4.0f, 4.0f, 7.0f, 3.0f),
|
||
|
|
Vector4(7.0f, -1.0f, 8.0f, 0.0f));
|
||
|
14 years ago
|
|
||
|
14 years ago
|
std::ostringstream o;
|
||
|
14 years ago
|
Debug(&o) << m;
|
||
|
|
CORRADE_COMPARE(o.str(), "Matrix(3, 4, 7,\n"
|
||
|
|
" 5, 4, -1,\n"
|
||
|
|
" 8, 7, 8,\n"
|
||
|
|
" 4, 3, 0)\n");
|
||
|
|
|
||
|
13 years ago
|
o.str({});
|
||
|
13 years ago
|
Debug(&o) << "a" << Matrix3x4() << "b" << RectangularMatrix<4, 3, Byte>();
|
||
|
14 years ago
|
CORRADE_COMPARE(o.str(), "a Matrix(0, 0, 0,\n"
|
||
|
|
" 0, 0, 0,\n"
|
||
|
|
" 0, 0, 0,\n"
|
||
|
|
" 0, 0, 0) b Matrix(0, 0, 0, 0,\n"
|
||
|
|
" 0, 0, 0, 0,\n"
|
||
|
|
" 0, 0, 0, 0)\n");
|
||
|
|
}
|
||
|
|
|
||
|
|
void RectangularMatrixTest::configuration() {
|
||
|
13 years ago
|
Matrix3x4 m(Vector4(3.0f, 5.0f, 8.0f, 4.0f),
|
||
|
|
Vector4(4.0f, 4.0f, 7.0f, 3.125f),
|
||
|
|
Vector4(7.0f, -1.0f, 8.0f, 9.55f));
|
||
|
14 years ago
|
std::string value("3 4 7 5 4 -1 8 7 8 4 3.125 9.55");
|
||
|
14 years ago
|
|
||
|
13 years ago
|
Corrade::Utility::Configuration c;
|
||
|
14 years ago
|
c.setValue<Matrix3x4>("matrix", m);
|
||
|
|
|
||
|
14 years ago
|
CORRADE_COMPARE(c.value("matrix"), value);
|
||
|
14 years ago
|
CORRADE_COMPARE(c.value<Matrix3x4>("matrix"), m);
|
||
|
14 years ago
|
}
|
||
|
|
|
||
|
|
}}}
|
||
|
14 years ago
|
|
||
|
|
CORRADE_TEST_MAIN(Magnum::Math::Test::RectangularMatrixTest)
|