|
|
@@ -55,84 +55,98 @@ TEST_CASE("libm", "")
|
|
|
REQUIRE(bx::equal( 0.89f, bx::fract( 13.89f), 0.000001f) );
|
|
|
REQUIRE(bx::equal(-0.89f, bx::fract(-13.89f), 0.000001f) );
|
|
|
|
|
|
+ bx::Error err;
|
|
|
+
|
|
|
for (int32_t yy = -10; yy < 10; ++yy)
|
|
|
{
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "ldexp(%f, %d) == %f (expected: %f)\n", xx, yy, bx::ldexp(xx, yy), ::ldexpf(xx, yy) );
|
|
|
+ bx::write(writer, &err, "ldexp(%f, %d) == %f (expected: %f)\n", xx, yy, bx::ldexp(xx, yy), ::ldexpf(xx, yy) );
|
|
|
REQUIRE(bx::equal(bx::ldexp(xx, yy), ::ldexpf(xx, yy), 0.00001f) );
|
|
|
}
|
|
|
}
|
|
|
|
|
|
for (float xx = -80.0f; xx < 80.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "exp(%f) == %f (expected: %f)\n", xx, bx::exp(xx), ::expf(xx) );
|
|
|
+ bx::write(writer, &err, "exp(%f) == %f (expected: %f)\n", xx, bx::exp(xx), ::expf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::exp(xx), ::expf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = 0.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "rsqrt(%f) == %f (expected: %f)\n", xx, bx::rsqrt(xx), 1.0f/::sqrtf(xx) );
|
|
|
+ bx::write(writer, &err, "rsqrt(%f) == %f (expected: %f)\n", xx, bx::rsqrt(xx), 1.0f/::sqrtf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::rsqrt(xx), 1.0f/::sqrtf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = 0.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "sqrt(%f) == %f (expected: %f)\n", xx, bx::sqrt(xx), ::sqrtf(xx) );
|
|
|
+ bx::write(writer, &err, "sqrt(%f) == %f (expected: %f)\n", xx, bx::sqrt(xx), ::sqrtf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::sqrt(xx), ::sqrtf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "pow(1.389f, %f) == %f (expected: %f)\n", xx, bx::pow(1.389f, xx), ::powf(1.389f, xx) );
|
|
|
+ bx::write(writer, &err, "pow(1.389f, %f) == %f (expected: %f)\n", xx, bx::pow(1.389f, xx), ::powf(1.389f, xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::pow(1.389f, xx), ::powf(1.389f, xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -1.0f; xx < 1.0f; xx += 0.001f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "asin(%f) == %f (expected: %f)\n", xx, bx::asin(xx), ::asinf(xx) );
|
|
|
+ bx::write(writer, &err, "asin(%f) == %f (expected: %f)\n", xx, bx::asin(xx), ::asinf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::asin(xx), ::asinf(xx), 0.0001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "sin(%f) == %f (expected: %f)\n", xx, bx::sin(xx), ::sinf(xx) );
|
|
|
+ bx::write(writer, &err, "sin(%f) == %f (expected: %f)\n", xx, bx::sin(xx), ::sinf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::sin(xx), ::sinf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -1.0f; xx < 1.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "sinh(%f) == %f (expected: %f)\n", xx, bx::sinh(xx), ::sinhf(xx) );
|
|
|
+ bx::write(writer, &err, "sinh(%f) == %f (expected: %f)\n", xx, bx::sinh(xx), ::sinhf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::sinh(xx), ::sinhf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -1.0f; xx < 1.0f; xx += 0.001f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "acos(%f) == %f (expected: %f\n)", xx, bx::acos(xx), ::acosf(xx) );
|
|
|
+ bx::write(writer, &err, "acos(%f) == %f (expected: %f\n)", xx, bx::acos(xx), ::acosf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::acos(xx), ::acosf(xx), 0.0001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "cos(%f) == %f (expected: %f)\n", xx, bx::cos(xx), ::cosf(xx) );
|
|
|
+ bx::write(writer, &err, "cos(%f) == %f (expected: %f)\n", xx, bx::cos(xx), ::cosf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::cos(xx), ::cosf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "tan(%f) == %f (expected: %f)\n", xx, bx::tan(xx), ::tanf(xx) );
|
|
|
+ bx::write(writer, &err, "tan(%f) == %f (expected: %f)\n", xx, bx::tan(xx), ::tanf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::tan(xx), ::tanf(xx), 0.001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -1.0f; xx < 1.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "tanh(%f) == %f (expected: %f\n", xx, bx::tanh(xx), ::tanhf(xx) );
|
|
|
+ bx::write(writer, &err, "tanh(%f) == %f (expected: %f\n", xx, bx::tanh(xx), ::tanhf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::tanh(xx), ::tanhf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "atan(%f) == %f (expected: %f)\n", xx, bx::atan(xx), ::atanf(xx) );
|
|
|
+ bx::write(writer, &err, "atan(%f) == %f (expected: %f)\n", xx, bx::atan(xx), ::atanf(xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::atan(xx), ::atanf(xx), 0.00001f) );
|
|
|
}
|
|
|
|
|
|
@@ -140,7 +154,8 @@ TEST_CASE("libm", "")
|
|
|
{
|
|
|
for (float xx = -100.0f; xx < 100.0f; xx += 0.1f)
|
|
|
{
|
|
|
- bx::writePrintf(writer, "atan2(%f, %f) == %f (expected: %f)\n", yy, xx, bx::atan2(yy, xx), ::atan2f(yy, xx) );
|
|
|
+ bx::write(writer, &err, "atan2(%f, %f) == %f (expected: %f)\n", yy, xx, bx::atan2(yy, xx), ::atan2f(yy, xx) );
|
|
|
+ REQUIRE(err.isOk() );
|
|
|
REQUIRE(bx::equal(bx::atan2(yy, xx), ::atan2f(yy, xx), 0.00001f) );
|
|
|
}
|
|
|
}
|