From ec04d9c03ddf12e46dca5348d4ca57b526e425f1 Mon Sep 17 00:00:00 2001 From: Mateusz Pusz Date: Wed, 14 Jun 2023 15:58:21 +0300 Subject: [PATCH] test: math static tests updated for V2 --- test/unit_test/static/CMakeLists.txt | 3 +- test/unit_test/static/math_test.cpp | 245 +++++++++++++++++---------- 2 files changed, 155 insertions(+), 93 deletions(-) diff --git a/test/unit_test/static/CMakeLists.txt b/test/unit_test/static/CMakeLists.txt index 4af05b6a..1eea6b74 100644 --- a/test/unit_test/static/CMakeLists.txt +++ b/test/unit_test/static/CMakeLists.txt @@ -47,9 +47,8 @@ add_library( isq_test.cpp isq_angle_test.cpp # magnitude_test.cpp - # math_test.cpp + math_test.cpp natural_test.cpp - # point_origin_test.cpp prime_test.cpp quantity_spec_test.cpp ratio_test.cpp diff --git a/test/unit_test/static/math_test.cpp b/test/unit_test/static/math_test.cpp index 1c4f129e..000a0ea9 100644 --- a/test/unit_test/static/math_test.cpp +++ b/test/unit_test/static/math_test.cpp @@ -20,124 +20,187 @@ // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE // SOFTWARE. -#include "test_tools.h" -#include -#include -#include -#include -#include -#include -#include -#include // IWYU pragma: keep +// #include "test_tools.h" +#include // IWYU pragma: keep +#include +#include +#include +#include namespace { using namespace mp_units; -using namespace mp_units::isq; -using namespace mp_units::isq::si::literals; -using namespace mp_units::isq::si::international::literals; +using namespace mp_units::si::unit_symbols; +using namespace mp_units::international::unit_symbols; -static_assert(compare(2_q_m)), std::int64_t>); -static_assert(compare(2_q_m)), decltype(2_q_m)>); -static_assert(compare(2_q_m)), decltype(4_q_m2)>); -static_assert(compare(2_q_km)), decltype(4_q_km2)>); -static_assert(compare(2_q_ft)), decltype(4_q_ft2)>); -static_assert(compare); -static_assert(compare); -static_assert(compare); -static_assert(compare); -static_assert(compare); -static_assert(compare); -static_assert(compare(4_q_m2 * 4_q_m2)), decltype(2_q_m)>); -static_assert(compare(4_q_km2 * 4_q_km2)), decltype(2_q_km)>); -static_assert(compare(4_q_ft2 * 4_q_ft2)), decltype(2_q_ft)>); +template +[[nodiscard]] consteval bool compare(T1 v1, T2 v2, Ts... vs) +{ + return is_same_v && v1 == v2 && (... && (v1 == vs)); +} -// rational dimensions -static_assert(compare(4_q_m2)), decltype(sqrt(2_q_m))>); -static_assert(compare(4_q_km2)), decltype(sqrt(2_q_km))>); -static_assert(compare(4_q_ft2)), decltype(sqrt(2_q_ft))>); +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)); +static_assert(compare(pow<2>(2 * km), 4 * pow<2>(km), 4 * square(km))); +static_assert(compare(pow<2>(2 * ft), 4 * pow<2>(ft), 4 * square(ft))); +static_assert(compare(sqrt(4 * m2), 2 * m)); +static_assert(compare(sqrt(4 * square(km)), 2 * km)); +static_assert(compare(sqrt(4 * square(ft)), 2 * ft)); +static_assert(compare(cbrt(8 * m3), 2 * m)); +static_assert(compare(cbrt(8 * cubic(km)), 2 * km)); +static_assert(compare(cbrt(8 * cubic(ft)), 2 * ft)); +static_assert(compare(pow<1, 4>(4 * m2 * (4 * m2)), 2 * m)); +static_assert(compare(pow<1, 4>(4 * square(km) * (4 * square(km))), 2 * km)); +static_assert(compare(pow<1, 4>(4 * square(ft) * (4 * square(ft))), 2 * ft)); +static_assert(compare(pow<1, 4>(4. * m2), std::sqrt(2.) * sqrt(m))); +static_assert(compare(pow<1, 4>(4. * square(km)), std::sqrt(2.) * sqrt(km))); +static_assert(compare(pow<1, 4>(4. * square(ft)), std::sqrt(2.) * sqrt(ft))); -#if __cpp_lib_constexpr_cmath +static_assert(compare(pow<0>(2 * isq::length[m]), 1 * dimensionless[one])); +static_assert(compare(pow<1>(2 * isq::length[m]), 2 * isq::length[m])); +static_assert(compare(pow<2>(2 * isq::length[m]), 4 * pow<2>(isq::length)[pow<2>(m)], 4 * isq::area[m2])); +static_assert(compare(pow<2>(2 * isq::length[km]), 4 * pow<2>(isq::length)[pow<2>(km)], 4 * isq::area[square(km)])); +static_assert(compare(pow<2>(2 * isq::length[ft]), 4 * pow<2>(isq::length)[pow<2>(ft)], 4 * isq::area[square(ft)])); +static_assert(compare(sqrt(4 * isq::area[m2]), 2 * pow<1, 2>(isq::area)[m], 2 * isq::length[m])); +static_assert(compare(sqrt(4 * isq::area[square(km)]), 2 * pow<1, 2>(isq::area)[km], 2 * isq::length[km])); +static_assert(compare(sqrt(4 * isq::area[square(ft)]), 2 * pow<1, 2>(isq::area)[ft], 2 * isq::length[ft])); +static_assert(compare(cbrt(8 * isq::volume[m3]), 2 * pow<1, 3>(isq::volume)[m], 2 * isq::length[m])); +static_assert(compare(cbrt(8 * isq::volume[cubic(km)]), 2 * pow<1, 3>(isq::volume)[km], 2 * isq::length[km])); +static_assert(compare(cbrt(8 * isq::volume[cubic(ft)]), 2 * pow<1, 3>(isq::volume)[ft], 2 * isq::length[ft])); +static_assert(compare(pow<1, 4>(4 * isq::area[m2] * (4 * isq::area[m2])), 2 * pow<1, 2>(isq::area)[m], + 2 * isq::length[m])); +static_assert(compare(pow<1, 4>(4 * isq::area[square(km)] * (4 * isq::area[square(km)])), 2 * pow<1, 2>(isq::area)[km], + 2 * isq::length[km])); +static_assert(compare(pow<1, 4>(4 * isq::area[square(ft)] * (4 * isq::area[square(ft)])), 2 * pow<1, 2>(isq::area)[ft], + 2 * isq::length[ft])); +static_assert(compare(pow<1, 4>(4. * isq::area[m2]), sqrt(2.) * pow<1, 4>(isq::area)[sqrt(m)], + std::sqrt(2.) * sqrt(isq::length[m]))); +static_assert(compare(pow<1, 4>(4. * isq::area[square(km)]), sqrt(2.) * pow<1, 4>(isq::area)[sqrt(km)], + std::sqrt(2.) * sqrt(isq::length[km]))); +static_assert(compare(pow<1, 4>(4. * isq::area[square(ft)]), sqrt(2.) * pow<1, 4>(isq::area)[sqrt(ft)], + std::sqrt(2.) * sqrt(isq::length[ft]))); + +// #if __cpp_lib_constexpr_cmath // floor // integral types -static_assert(compare(1_q_s)), decltype(1_q_s)>); +static_assert(compare(floor(1 * s), 1 * s)); +static_assert(compare(floor(1000 * ms), 1 * s)); +static_assert(compare(floor(1001 * ms), 1 * s)); +static_assert(compare(floor(1999 * ms), 1 * s)); +static_assert(compare(floor(-1000 * ms), -1 * s)); +static_assert(compare(floor(-999 * ms), -1 * s)); -static_assert(compare(1000_q_ms)), decltype(1_q_s)>); -static_assert(compare(1001_q_ms)), decltype(1_q_s)>); -static_assert(compare(1999_q_ms)), decltype(1_q_s)>); -static_assert(compare(-1000_q_ms)), decltype(-1_q_s)>); -static_assert(compare(-999_q_ms)), decltype(-1_q_s)>); +static_assert(compare(floor(1 * isq::time[s]), 1 * isq::time[s])); +static_assert(compare(floor(1000 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(floor(1001 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(floor(1999 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(floor(-1000 * isq::time[ms]), -1 * isq::time[s])); +static_assert(compare(floor(-999 * isq::time[ms]), -1 * isq::time[s])); // floating-point -static_assert(floor(1.3_q_s) == 1_q_s); -static_assert(floor(-1.3_q_s) == -2_q_s); +static_assert(compare(floor(1.3 * s), 1. * s)); +static_assert(compare(floor(-1.3 * s), -2. * s)); +static_assert(compare(floor(1000. * ms), 1. * s)); +static_assert(compare(floor(1001. * ms), 1. * s)); +static_assert(compare(floor(1999. * ms), 1. * s)); +static_assert(compare(floor(-1000. * ms), -1. * s)); +static_assert(compare(floor(-999. * ms), -1. * s)); -static_assert(floor(1000._q_ms) == 1_q_s); -static_assert(floor(1001._q_ms) == 1_q_s); -static_assert(floor(1999._q_ms) == 1_q_s); -static_assert(floor(-1000._q_ms) == -1_q_s); -static_assert(floor(-999._q_ms) == -1_q_s); - -// floor with quantity -static_assert(compare>(1_q_s)), decltype(1_q_s)>); +static_assert(compare(floor(1.3 * isq::time[s]), 1. * isq::time[s])); +static_assert(compare(floor(-1.3 * isq::time[s]), -2. * isq::time[s])); +static_assert(compare(floor(1000. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(floor(1001. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(floor(1999. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(floor(-1000. * isq::time[ms]), -1. * isq::time[s])); +static_assert(compare(floor(-999. * isq::time[ms]), -1. * isq::time[s])); // ceil // integral types -static_assert(compare(1_q_s)), decltype(1_q_s)>); +static_assert(compare(ceil(1 * s), 1 * s)); +static_assert(compare(ceil(1000 * ms), 1 * s)); +static_assert(compare(ceil(1001 * ms), 2 * s)); +static_assert(compare(ceil(1999 * ms), 2 * s)); +static_assert(compare(ceil(-1000 * ms), -1 * s)); +static_assert(compare(ceil(-999 * ms), 0 * s)); -static_assert(compare(1000_q_ms)), decltype(1_q_s)>); -static_assert(compare(1001_q_ms)), decltype(2_q_s)>); -static_assert(compare(1999_q_ms)), decltype(2_q_s)>); -static_assert(compare(-1000_q_ms)), decltype(-1_q_s)>); -static_assert(compare(-999_q_ms)), decltype(0_q_s)>); +static_assert(compare(ceil(1 * isq::time[s]), 1 * isq::time[s])); +static_assert(compare(ceil(1000 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(ceil(1001 * isq::time[ms]), 2 * isq::time[s])); +static_assert(compare(ceil(1999 * isq::time[ms]), 2 * isq::time[s])); +static_assert(compare(ceil(-1000 * isq::time[ms]), -1 * isq::time[s])); +static_assert(compare(ceil(-999 * isq::time[ms]), 0 * isq::time[s])); // floating-point -static_assert(ceil(1.3_q_s) == 2_q_s); -static_assert(ceil(-1.3_q_s) == -1_q_s); +static_assert(compare(ceil(1.3 * s), 2. * s)); +static_assert(compare(ceil(-1.3 * s), -1. * s)); +static_assert(compare(ceil(1000. * ms), 1. * s)); +static_assert(compare(ceil(1001. * ms), 2. * s)); +static_assert(compare(ceil(1999. * ms), 2. * s)); +static_assert(compare(ceil(-1000. * ms), -1. * s)); +static_assert(compare(ceil(-999. * ms), 0. * s)); -static_assert(ceil(1000._q_ms) == 1_q_s); -static_assert(ceil(1001._q_ms) == 2_q_s); -static_assert(ceil(1999._q_ms) == 2_q_s); -static_assert(ceil(-1000._q_ms) == -1_q_s); -static_assert(ceil(-999._q_ms) == 0_q_s); - -// ceil with quantity -static_assert(compare>(1_q_s)), decltype(1_q_s)>); +static_assert(compare(ceil(1.3 * isq::time[s]), 2. * isq::time[s])); +static_assert(compare(ceil(-1.3 * isq::time[s]), -1. * isq::time[s])); +static_assert(compare(ceil(1000. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(ceil(1001. * isq::time[ms]), 2. * isq::time[s])); +static_assert(compare(ceil(1999. * isq::time[ms]), 2. * isq::time[s])); +static_assert(compare(ceil(-1000. * isq::time[ms]), -1. * isq::time[s])); +static_assert(compare(ceil(-999. * isq::time[ms]), 0. * isq::time[s])); // round // integral types -static_assert(compare(1_q_s)), decltype(1_q_s)>); +static_assert(compare(round(1 * s), 1 * s)); +static_assert(compare(round(1000 * ms), 1 * s)); +static_assert(compare(round(1001 * ms), 1 * s)); +static_assert(compare(round(1499 * ms), 1 * s)); +static_assert(compare(round(1500 * ms), 2 * s)); +static_assert(compare(round(1999 * ms), 2 * s)); +static_assert(compare(round(-1000 * ms), -1 * s)); +static_assert(compare(round(-1001 * ms), -1 * s)); +static_assert(compare(round(-1499 * ms), -1 * s)); +static_assert(compare(round(-1500 * ms), -2 * s)); +static_assert(compare(round(-1999 * ms), -2 * s)); -static_assert(compare(1000_q_ms)), decltype(1_q_s)>); -static_assert(compare(1001_q_ms)), decltype(1_q_s)>); -static_assert(compare(1499_q_ms)), decltype(1_q_s)>); -static_assert(compare(1500_q_ms)), decltype(2_q_s)>); -static_assert(compare(1999_q_ms)), decltype(2_q_s)>); - -static_assert(compare(-1000_q_ms)), decltype(-1_q_s)>); -static_assert(compare(-1001_q_ms)), decltype(-1_q_s)>); -static_assert(compare(-1499_q_ms)), decltype(-1_q_s)>); -static_assert(compare(-1500_q_ms)), decltype(-2_q_s)>); -static_assert(compare(-1999_q_ms)), decltype(-2_q_s)>); +static_assert(compare(round(1 * isq::time[s]), 1 * isq::time[s])); +static_assert(compare(round(1000 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(round(1001 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(round(1499 * isq::time[ms]), 1 * isq::time[s])); +static_assert(compare(round(1500 * isq::time[ms]), 2 * isq::time[s])); +static_assert(compare(round(1999 * isq::time[ms]), 2 * isq::time[s])); +static_assert(compare(round(-1000 * isq::time[ms]), -1 * isq::time[s])); +static_assert(compare(round(-1001 * isq::time[ms]), -1 * isq::time[s])); +static_assert(compare(round(-1499 * isq::time[ms]), -1 * isq::time[s])); +static_assert(compare(round(-1500 * isq::time[ms]), -2 * isq::time[s])); +static_assert(compare(round(-1999 * isq::time[ms]), -2 * isq::time[s])); // floating-point -static_assert(round(1.3_q_s) == 1_q_s); -static_assert(round(-1.3_q_s) == -1_q_s); +static_assert(compare(round(1.3 * s), 1. * s)); +static_assert(compare(round(-1.3 * s), -1. * s)); +static_assert(compare(round(1000. * ms), 1. * s)); +static_assert(compare(round(1001. * ms), 1. * s)); +static_assert(compare(round(1499. * ms), 1. * s)); +static_assert(compare(round(1500. * ms), 2. * s)); +static_assert(compare(round(1999. * ms), 2. * s)); +static_assert(compare(round(-1000. * ms), -1. * s)); +static_assert(compare(round(-1001. * ms), -1. * s)); +static_assert(compare(round(-1499. * ms), -1. * s)); +static_assert(compare(round(-1500. * ms), -2. * s)); +static_assert(compare(round(-1999. * ms), -2. * s)); -static_assert(compare(1000._q_ms)), decltype(1._q_s)>); -static_assert(compare(1001._q_ms)), decltype(1._q_s)>); -static_assert(compare(1499._q_ms)), decltype(1._q_s)>); -static_assert(compare(1500._q_ms)), decltype(2._q_s)>); -static_assert(compare(1999._q_ms)), decltype(2._q_s)>); +static_assert(compare(round(1.3 * isq::time[s]), 1. * isq::time[s])); +static_assert(compare(round(-1.3 * isq::time[s]), -1. * isq::time[s])); +static_assert(compare(round(1000. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(round(1001. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(round(1499. * isq::time[ms]), 1. * isq::time[s])); +static_assert(compare(round(1500. * isq::time[ms]), 2. * isq::time[s])); +static_assert(compare(round(1999. * isq::time[ms]), 2. * isq::time[s])); +static_assert(compare(round(-1000. * isq::time[ms]), -1. * isq::time[s])); +static_assert(compare(round(-1001. * isq::time[ms]), -1. * isq::time[s])); +static_assert(compare(round(-1499. * isq::time[ms]), -1. * isq::time[s])); +static_assert(compare(round(-1500. * isq::time[ms]), -2. * isq::time[s])); +static_assert(compare(round(-1999. * isq::time[ms]), -2. * isq::time[s])); -static_assert(compare(-1000._q_ms)), decltype(-1._q_s)>); -static_assert(compare(-1001._q_ms)), decltype(-1._q_s)>); -static_assert(compare(-1499._q_ms)), decltype(-1._q_s)>); -static_assert(compare(-1500._q_ms)), decltype(-2._q_s)>); -static_assert(compare(-1999._q_ms)), decltype(-2._q_s)>); - -// round with quantity -static_assert(compare>(1_q_s)), decltype(1_q_s)>); -#endif +// #endif } // namespace