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.
168 lines
4.7 KiB
168 lines
4.7 KiB
/* |
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
|
|
|
This file is part of Magnum. |
|
|
|
Magnum is free software: you can redistribute it and/or modify |
|
it under the terms of the GNU Lesser General Public License version 3 |
|
only, as published by the Free Software Foundation. |
|
|
|
Magnum is distributed in the hope that it will be useful, |
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
GNU Lesser General Public License version 3 for more details. |
|
*/ |
|
|
|
#include "VectorTest.h" |
|
|
|
#include <sstream> |
|
|
|
#include "Vector.h" |
|
#include "Math.h" |
|
|
|
CORRADE_TEST_MAIN(Magnum::Math::Test::VectorTest) |
|
|
|
using namespace std; |
|
using namespace Corrade::Utility; |
|
|
|
namespace Magnum { namespace Math { namespace Test { |
|
|
|
typedef Vector<4, float> Vector4; |
|
typedef Vector<3, float> Vector3; |
|
|
|
VectorTest::VectorTest() { |
|
addTests(&VectorTest::construct, |
|
&VectorTest::data, |
|
&VectorTest::copy, |
|
&VectorTest::dot, |
|
&VectorTest::multiplyDivide, |
|
&VectorTest::addSubstract, |
|
&VectorTest::dotSelf, |
|
&VectorTest::length, |
|
&VectorTest::normalized, |
|
&VectorTest::sum, |
|
&VectorTest::product, |
|
&VectorTest::min, |
|
&VectorTest::max, |
|
&VectorTest::angle, |
|
&VectorTest::negative, |
|
&VectorTest::debug); |
|
} |
|
|
|
void VectorTest::construct() { |
|
CORRADE_COMPARE(Vector4(), Vector4(0.0f, 0.0f, 0.0f, 0.0f)); |
|
|
|
float data[] = { 1.0f, 2.0f, 3.0f, 4.0f }; |
|
CORRADE_COMPARE(Vector4::from(data), Vector4(1.0f, 2.0f, 3.0f, 4.0f)); |
|
} |
|
|
|
void VectorTest::data() { |
|
Vector4 v; |
|
v[2] = 1.5f; |
|
|
|
v[0] = 1.0f; |
|
|
|
CORRADE_COMPARE(v, Vector4(1.0f, 0.0f, 1.5f, 0.0f)); |
|
} |
|
|
|
void VectorTest::copy() { |
|
Vector4 v1; |
|
|
|
v1[3] = 1.0f; |
|
|
|
Vector4 v2(v1); |
|
Vector4 v3; |
|
v3[0] = 0.0f; /* this line is here so it's not optimized to Vector4 v3(v1) */ |
|
v3 = v1; |
|
|
|
/* Change original */ |
|
v1[2] = 1.0f; |
|
|
|
/* Verify the copy is the same as original original */ |
|
Vector4 original; |
|
original[3] = 1.0f; |
|
|
|
CORRADE_COMPARE(v2, original); |
|
CORRADE_COMPARE(v3, original); |
|
} |
|
|
|
void VectorTest::dot() { |
|
CORRADE_COMPARE(Vector4::dot({1.0f, 0.5f, 0.75f, 1.5f}, {2.0f, 4.0f, 1.0f, 7.0f}), 15.25f); |
|
} |
|
|
|
void VectorTest::multiplyDivide() { |
|
Vector4 vec(1.0f, 2.0f, 3.0f, 4.0f); |
|
Vector4 multiplied(-1.5f, -3.0f, -4.5f, -6.0f); |
|
|
|
CORRADE_COMPARE(vec*-1.5f, multiplied); |
|
CORRADE_COMPARE(multiplied/-1.5f, vec); |
|
|
|
Math::Vector<1, char> vecChar(32); |
|
Math::Vector<1, char> multipliedChar(-48); |
|
CORRADE_COMPARE(vecChar*-1.5f, multipliedChar); |
|
CORRADE_COMPARE(multipliedChar/-1.5f, vecChar); |
|
} |
|
|
|
void VectorTest::addSubstract() { |
|
Vector4 a(0.5f, -7.5f, 9.0f, -11.0f); |
|
Vector4 b(-0.5, 1.0f, 0.0f, 7.5f); |
|
Vector4 expected(0.0f, -6.5f, 9.0f, -3.5f); |
|
|
|
CORRADE_COMPARE(a + b, expected); |
|
CORRADE_COMPARE(expected - b, a); |
|
} |
|
|
|
void VectorTest::dotSelf() { |
|
CORRADE_COMPARE(Vector4(1.0f, 2.0f, 3.0f, 4.0f).dot(), 30.0f); |
|
} |
|
|
|
void VectorTest::length() { |
|
CORRADE_COMPARE(Vector4(1.0f, 2.0f, 3.0f, 4.0f).length(), 5.4772256f); |
|
} |
|
|
|
void VectorTest::normalized() { |
|
CORRADE_COMPARE(Vector4(1.0f, 1.0f, 1.0f, 1.0f).normalized(), Vector4(0.5f, 0.5f, 0.5f, 0.5f)); |
|
} |
|
|
|
void VectorTest::sum() { |
|
CORRADE_COMPARE(Vector3(1.0f, 2.0f, 4.0f).sum(), 7.0f); |
|
} |
|
|
|
void VectorTest::product() { |
|
CORRADE_COMPARE(Vector3(1.0f, 2.0f, 3.0f).product(), 6.0f); |
|
} |
|
|
|
void VectorTest::min() { |
|
CORRADE_COMPARE(Vector3(1.0f, -2.0f, 3.0f).min(), -2.0f); |
|
} |
|
|
|
void VectorTest::max() { |
|
CORRADE_COMPARE(Vector3(1.0f, -2.0f, 3.0f).max(), 3.0f); |
|
} |
|
|
|
void VectorTest::angle() { |
|
ostringstream o; |
|
Error::setOutput(&o); |
|
/* Both vectors must be normalized, otherwise NaN is returned */ |
|
CORRADE_COMPARE(Vector3::angle(Vector3(2.0f, 3.0f, 4.0f).normalized(), {1.0f, -2.0f, 3.0f}), numeric_limits<Vector3::Type>::quiet_NaN()); |
|
CORRADE_COMPARE(o.str(), "Math::Vector::angle(): vectors must be normalized!\n"); |
|
CORRADE_COMPARE(Vector3::angle({2.0f, 3.0f, 4.0f}, Vector3(1.0f, -2.0f, 3.0f).normalized()), numeric_limits<Vector3::Type>::quiet_NaN()); |
|
|
|
CORRADE_COMPARE(Vector3::angle(Vector3(2.0f, 3.0f, 4.0f).normalized(), Vector3(1.0f, -2.0f, 3.0f).normalized()), rad(1.162514f)); |
|
} |
|
|
|
void VectorTest::negative() { |
|
CORRADE_COMPARE(-Vector4(1.0f, -3.0f, 5.0f, -10.0f), Vector4(-1.0f, 3.0f, -5.0f, 10.0f)); |
|
} |
|
|
|
void VectorTest::debug() { |
|
ostringstream o; |
|
Debug(&o) << Vector4(0.5f, 15.0f, 1.0f, 1.0f); |
|
CORRADE_COMPARE(o.str(), "Vector(0.5, 15, 1, 1)\n"); |
|
|
|
o.str(""); |
|
Debug(&o) << "a" << Vector4() << "b" << Vector4(); |
|
CORRADE_COMPARE(o.str(), "a Vector(0, 0, 0, 0) b Vector(0, 0, 0, 0)\n"); |
|
} |
|
|
|
}}}
|
|
|