mirror of
https://github.com/mpusz/mp-units.git
synced 2025-08-04 12:54:25 +02:00
feat: IEEE floating-point division remainder
This commit is contained in:
@@ -89,6 +89,24 @@ TEST_CASE("fmod functions", "[math][fmod]")
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("remainder functions", "[math][remainder]")
|
||||
{
|
||||
SECTION("remainder should work on the same quantities")
|
||||
{
|
||||
REQUIRE(remainder(4. * isq::length[km], 3. * isq::length[km]) == 1. * isq::length[km]);
|
||||
REQUIRE(remainder(-9. * isq::length[km], 3. * isq::length[km]) == -0. * isq::length[km]);
|
||||
REQUIRE(remainder(3 * isq::length[km], 2 * isq::length[km]) == -1 * isq::length[km]);
|
||||
REQUIRE(remainder(4 * isq::length[km], 2.75f * isq::length[km]) == 1.25 * isq::length[km]);
|
||||
}
|
||||
SECTION("remainder should work with different units of the same dimension")
|
||||
{
|
||||
REQUIRE(remainder(4. * isq::length[km], 3000. * isq::length[m]) == 1000. * isq::length[m]);
|
||||
REQUIRE(remainder(-9. * isq::length[km], 3000. * isq::length[m]) == -0. * isq::length[m]);
|
||||
REQUIRE(remainder(3. * isq::length[km], 2000. * isq::length[m]) == -1000 * isq::length[m]);
|
||||
REQUIRE(remainder(4 * isq::length[km], 2750 * isq::length[m]) == 1250 * isq::length[m]);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("'isfinite()' accepts dimensioned arguments", "[math][isfinite]") { REQUIRE(isfinite(4.0 * isq::length[m])); }
|
||||
|
||||
TEST_CASE("'isinf()' accepts dimensioned arguments", "[math][isinf]") { REQUIRE(!isinf(4.0 * isq::length[m])); }
|
||||
|
@@ -59,6 +59,12 @@ static_assert(compare(fmod(9.0 * km, -3.0 * km), 0.0 * km));
|
||||
static_assert(compare(fmod(9.5 * km, -2000 * m), 1500.0 * m));
|
||||
static_assert(compare(fmod(3 * km, 2 * km), 1.0 * km));
|
||||
static_assert(compare(fmod(4 * km, 2.5f * km), 1.5 * km));
|
||||
static_assert(compare(remainder(4.0 * km, 3.0 * km), 1.0 * km));
|
||||
static_assert(compare(remainder(-4.0 * km, 3.0 * km), -1.0 * km));
|
||||
static_assert(compare(remainder(9.0 * km, -3.0 * km), 0.0 * km));
|
||||
static_assert(compare(remainder(9.5 * km, -2000 * m), -500.0 * m));
|
||||
static_assert(compare(remainder(3 * km, 2 * km), -1.0 * km));
|
||||
static_assert(compare(remainder(4 * km, 2.75f * km), 1.25 * km));
|
||||
static_assert(compare(pow<0>(2 * m), 1 * one));
|
||||
static_assert(compare(pow<1>(2 * m), 2 * m));
|
||||
static_assert(compare(pow<2>(2 * m), 4 * pow<2>(m), 4 * m2));
|
||||
|
Reference in New Issue
Block a user