📄 angle_test.cpp
字号:
//===========================================================================//
// File: angle.tst //
// Contents: Tests for angle classes //
//---------------------------------------------------------------------------//
// Copyright (C) Microsoft Corporation. All rights reserved. //
//===========================================================================//
#include "StuffHeaders.hpp"
//
//#############################################################################
//#############################################################################
//
bool
Radian::TestClass()
{
SPEW((GROUP_STUFF_TEST, "Starting Radian Test..."));
const Radian a(1.25f);
Radian
b,c;
Test_Assumption(a);
c = 0.0f;
Test_Assumption(!c);
Test_Assumption(Normalize(3.1f) == 3.1f);
Test_Assumption(Normalize(-3.1f) == -3.1f);
Scalar f = Normalize(Pi+Pi_Over_2);
Test_Assumption(Close_Enough(f,Pi_Over_2 - Pi));
f = Normalize(-Pi-Pi_Over_2);
Test_Assumption(Close_Enough(f,Pi - Pi_Over_2));
c = a;
#if 0
Test_Assumption(c == a);
Test_Assumption(c.angle == a);
Test_Assumption(c == a.angle);
#endif
b.Negate(c);
#if 0
Test_Assumption(b == -c.angle);
#endif
#if 0
b = -c;
d.Add(b,c);
Test_Assumption(d == b.angle + c.angle);
Test_Assumption(a+b == a.angle + b.angle);
Test_Assumption(a+c == a.angle + c.angle);
Test_Assumption(a+1.25f == a.angle+1.25f);
Test_Assumption(1.25f+c == 1.25f+c.angle);
c = 1.5f;
d.Subtract(c,a);
Test_Assumption(d == c.angle - a.angle);
Test_Assumption(c-a == c.angle - a.angle);
Test_Assumption(c-1.25f == c.angle - 1.25f);
Test_Assumption(1.5f-a == 1.5f - a.angle);
Test_Assumption(c-b == c.angle - b.angle);
c = 2.5f;
d.Multiply(a,c);
Test_Assumption(d == a.angle * c.angle);
Test_Assumption(a*c == a.angle * c.angle);
Test_Assumption(1.25f*c == 1.25f * c.angle);
Test_Assumption(a*2.5f == a.angle * 2.5f);
Test_Assumption(a*b == a.angle * b.angle);
c = 2.0f;
d.Divide(a,c);
Test_Assumption(d == a.angle / c.angle);
Test_Assumption(a/c == a.angle / c.angle);
Test_Assumption(1.25f/c == 1.25f / c.angle);
Test_Assumption(a/2.0f == a.angle / 2.0f);
Test_Assumption(a/b == a.angle / b.angle);
b = a;
b += c;
b.Normalize();
Test_Assumption(b == 3.25f - TWO_PI);
b += 2.0f;
b.Normalize();
Test_Assumption(b == 5.25f - TWO_PI);
b -= c;
b.Normalize();
Test_Assumption(b == 3.25f - TWO_PI);
b -= 2.0f;
b.Normalize();
Test_Assumption(b == 1.25f);
b *= c;
b.Normalize();
Test_Assumption(b == 1.25f*2.0f);
b *= 2.0f;
b.Normalize();
Test_Assumption(b == 1.25f*2.0f*2.0f - TWO_PI);
b = a*c;
b.Normalize();
Test_Assumption(b == 1.25f*2.0f);
b /= 2.0f;
b.Normalize();
Test_Assumption(b == 1.25f);
b = -3.0f*PI_OVER_4;
c = 3.0f*PI_OVER_4;
Test_Assumption(Lerp(b,c,0.25f) < b);
Test_Assumption(Normalize(Lerp(b,c,0.75f)) > c);
#endif
return true;
}
//
//#############################################################################
//#############################################################################
//
bool
Degree::TestClass()
{
SPEW((GROUP_STUFF_TEST, "Starting Degree test..."));
const Degree a(Degrees_Per_Radian);
Degree
b,c;
Radian
r(1.0f),s;
s = a;
Test_Assumption(r == s);
b = r;
s = b;
#if 0
Test_Assumption(r == s);
#endif
c = Degrees_Per_Radian;
s = c;
#if 0
Test_Assumption(r == s);
#endif
b = c;
s = b;
#if 0
Test_Assumption(r == s);
#endif
return true;
}
//
//#############################################################################
//#############################################################################
//
bool
SinCosPair::TestClass()
{
SPEW((GROUP_STUFF_TEST, "Starting SinCos test..."));
Radian
s,r(Pi_Over_2);
SinCosPair a;
a = r;
Test_Assumption(Close_Enough(a.sine,1.0f));
Test_Assumption(Small_Enough(a.cosine));
s = a;
Test_Assumption(s == r);
return true;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -