#include "Testing/NumericTesting.h" #include "Numeric/Numeric.h" #include "Miscellaneous/AssertionMacros.h" NAMESPACE_REDCRAFT_BEGIN NAMESPACE_MODULE_BEGIN(Redcraft) NAMESPACE_MODULE_BEGIN(Utility) NAMESPACE_BEGIN(Testing) void TestNumeric() { TestLiteral(); TestBit(); TestMath(); } void TestLiteral() { // always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); always_check((CSameAs)); } void TestBit() { always_check(Math::ByteSwap(0x00 ) == 0x00 ); always_check(Math::ByteSwap(0x0011 ) == 0x1100 ); always_check(Math::ByteSwap(0x00112233 ) == 0x33221100 ); always_check(Math::ByteSwap(0x0011223344556677) == 0x7766554433221100); always_check(Math::IsSingleBit(0b0000u) == false); always_check(Math::IsSingleBit(0b0001u) == true ); always_check(Math::IsSingleBit(0b0010u) == true ); always_check(Math::IsSingleBit(0b0011u) == false); always_check(Math::IsSingleBit(0b0100u) == true ); always_check(Math::IsSingleBit(0b0101u) == false); always_check(Math::IsSingleBit(0b0110u) == false); always_check(Math::IsSingleBit(0b0111u) == false); always_check(Math::IsSingleBit(0b1000u) == true ); always_check(Math::IsSingleBit(0b1001u) == false); always_check(Math::CountAllZero(0b00000000u8) == 8); always_check(Math::CountAllZero(0b11111111u8) == 0); always_check(Math::CountAllZero(0b00011101u8) == 4); always_check(Math::CountAllOne(0b00000000u8) == 0); always_check(Math::CountAllOne(0b11111111u8) == 8); always_check(Math::CountAllOne(0b00011101u8) == 4); always_check(Math::CountLeftZero(0b00000000u8) == 8); always_check(Math::CountLeftZero(0b11111111u8) == 0); always_check(Math::CountLeftZero(0b00011100u8) == 3); always_check(Math::CountLeftOne(0b00000000u8) == 0); always_check(Math::CountLeftOne(0b11111111u8) == 8); always_check(Math::CountLeftOne(0b11100011u8) == 3); always_check(Math::CountRightZero(0b00000000u8) == 8); always_check(Math::CountRightZero(0b11111111u8) == 0); always_check(Math::CountRightZero(0b00011100u8) == 2); always_check(Math::CountRightOne(0b00000000u8) == 0); always_check(Math::CountRightOne(0b11111111u8) == 8); always_check(Math::CountRightOne(0b11100011u8) == 2); always_check(Math::BitWidth(0b0000u) == 0); always_check(Math::BitWidth(0b0001u) == 1); always_check(Math::BitWidth(0b0010u) == 2); always_check(Math::BitWidth(0b0011u) == 2); always_check(Math::BitWidth(0b0100u) == 3); always_check(Math::BitWidth(0b0101u) == 3); always_check(Math::BitWidth(0b0110u) == 3); always_check(Math::BitWidth(0b0111u) == 3); always_check(Math::BitCeil(0b00000000u) == 0b00000001u); always_check(Math::BitCeil(0b00000001u) == 0b00000001u); always_check(Math::BitCeil(0b00000010u) == 0b00000010u); always_check(Math::BitCeil(0b00000011u) == 0b00000100u); always_check(Math::BitCeil(0b00000100u) == 0b00000100u); always_check(Math::BitCeil(0b00000101u) == 0b00001000u); always_check(Math::BitCeil(0b00000110u) == 0b00001000u); always_check(Math::BitCeil(0b00000111u) == 0b00001000u); always_check(Math::BitCeil(0b00001000u) == 0b00001000u); always_check(Math::BitCeil(0b00001001u) == 0b00010000u); always_check(Math::BitFloor(0b00000000u) == 0b00000000u); always_check(Math::BitFloor(0b00000001u) == 0b00000001u); always_check(Math::BitFloor(0b00000010u) == 0b00000010u); always_check(Math::BitFloor(0b00000011u) == 0b00000010u); always_check(Math::BitFloor(0b00000100u) == 0b00000100u); always_check(Math::BitFloor(0b00000101u) == 0b00000100u); always_check(Math::BitFloor(0b00000110u) == 0b00000100u); always_check(Math::BitFloor(0b00000111u) == 0b00000100u); always_check(Math::BitFloor(0b00001000u) == 0b00001000u); always_check(Math::BitFloor(0b00001001u) == 0b00001000u); always_check(Math::RotateLeft(0b00011101u8, 0) == 0b00011101u8); always_check(Math::RotateLeft(0b00011101u8, 1) == 0b00111010u8); always_check(Math::RotateLeft(0b00011101u8, 4) == 0b11010001u8); always_check(Math::RotateLeft(0b00011101u8, 9) == 0b00111010u8); always_check(Math::RotateLeft(0b00011101u8, -1) == 0b10001110u8); always_check(Math::RotateRight(0b00011101u8, 0) == 0b00011101u8); always_check(Math::RotateRight(0b00011101u8, 1) == 0b10001110u8); always_check(Math::RotateRight(0b00011101u8, 4) == 0b11010001u8); always_check(Math::RotateRight(0b00011101u8, 9) == 0b10001110u8); always_check(Math::RotateRight(0b00011101u8, -1) == 0b00111010u8); } void TestMath() { always_check(Math::Abs(-1) == 1); always_check(Math::Abs( 0) == 0); always_check(Math::Abs( 1) == 1); always_check(Math::Sign(-4) == -1); always_check(Math::Sign( 0) == 0); always_check(Math::Sign( 4) == 1); always_check(Math::Min(1, 2, 3, 4, 5) == 1); always_check(Math::Min(5, 4, 3, 2, 1) == 1); always_check(Math::Max(1, 2, 3, 4, 5) == 5); always_check(Math::Max(5, 4, 3, 2, 1) == 5); always_check(Math::IsNearlyEqual(4.0, 4.0)); always_check(Math::IsNearlyZero(0.0)); always_check(Math::IsInfinity( TNumericLimits::Infinity())); always_check(Math::IsInfinity(-TNumericLimits::Infinity())); always_check(Math::IsNaN( TNumericLimits::QuietNaN())); always_check(Math::IsNaN(-TNumericLimits::QuietNaN())); always_check(Math::IsNaN( TNumericLimits::SignalingNaN())); always_check(Math::IsNaN(-TNumericLimits::SignalingNaN())); always_check(Math::IsNaN(Math::NaN(4u))); always_check(Math::IsNormal(1.0e4)); always_check(Math::IsNormal(1.0e8)); always_check(!Math::IsNegative(+1.0)); always_check(!Math::IsNegative(+0.0)); always_check( Math::IsNegative(-0.0)); always_check( Math::IsNegative(-1.0)); always_check(Math::Exponent(1.0) == 0); always_check(Math::Exponent(2.0) == 1); always_check(Math::Exponent(4.0) == 2); always_check(Math::NaNPayload(Math::NaN(4u)) == 4u); enum class ETest : uint16 { A = 65535 }; always_check(Math::NaNPayload(Math::NaN(ETest::A)) == ETest::A); } NAMESPACE_END(Testing) NAMESPACE_MODULE_END(Utility) NAMESPACE_MODULE_END(Redcraft) NAMESPACE_REDCRAFT_END