// The MIT License (MIT) // // Copyright (c) 2018 Mateusz Pusz // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in all // copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE // SOFTWARE. #include #ifdef MP_UNITS_IMPORT_STD import std; #else #include #if MP_UNITS_HOSTED #include #endif // MP_UNITS_HOSTED #endif namespace { // ********************* QUANTITY ********************* using q_double = mp_units::quantity; using q_int = mp_units::quantity; // cv qualifiers static_assert(std::numeric_limits::max() == q_double::max()); static_assert(std::numeric_limits::max() == q_double::max()); static_assert(std::numeric_limits::max() == q_double::max()); // is_specialized static_assert(std::numeric_limits::is_specialized == true); static_assert(std::numeric_limits::is_specialized == true); // is_integer static_assert(std::numeric_limits::is_integer == false); static_assert(std::numeric_limits::is_integer == true); // has_infinity static_assert(std::numeric_limits::has_infinity == true); static_assert(std::numeric_limits::has_infinity == false); // min static_assert(std::numeric_limits::min() == q_double::min()); static_assert(std::numeric_limits::min() == q_int::min()); static_assert(std::numeric_limits::min().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); static_assert(std::numeric_limits::min().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); // max static_assert(std::numeric_limits::max() == q_double::max()); static_assert(std::numeric_limits::max() == q_int::max()); static_assert(std::numeric_limits::max().numerical_value_in(mp_units::si::metre) == std::numeric_limits::max()); static_assert(std::numeric_limits::max().numerical_value_in(mp_units::si::metre) == std::numeric_limits::max()); // lowest static_assert(std::numeric_limits::lowest().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); static_assert(std::numeric_limits::lowest().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); // epsilon static_assert(std::numeric_limits::epsilon().numerical_value_in(mp_units::si::metre) == std::numeric_limits::epsilon()); static_assert(std::numeric_limits::epsilon().numerical_value_in(mp_units::si::metre) == std::numeric_limits::epsilon()); // round_error static_assert(std::numeric_limits::round_error().numerical_value_in(mp_units::si::metre) == std::numeric_limits::round_error()); static_assert(std::numeric_limits::round_error().numerical_value_in(mp_units::si::metre) == std::numeric_limits::round_error()); // infinity static_assert(std::numeric_limits::infinity().numerical_value_in(mp_units::si::metre) == std::numeric_limits::infinity()); static_assert(std::numeric_limits::infinity().numerical_value_in(mp_units::si::metre) == std::numeric_limits::infinity()); #if MP_UNITS_HOSTED && (__cpp_lib_constexpr_cmath || MP_UNITS_COMP_GCC) // quiet_NaN static_assert(std::isnan(std::numeric_limits::quiet_NaN().numerical_value_in(mp_units::si::metre))); // signaling_NaN static_assert(std::isnan(std::numeric_limits::signaling_NaN().numerical_value_in(mp_units::si::metre))); #endif // denorm_min static_assert(std::numeric_limits::denorm_min().numerical_value_in(mp_units::si::metre) == std::numeric_limits::denorm_min()); static_assert(std::numeric_limits::denorm_min().numerical_value_in(mp_units::si::metre) == std::numeric_limits::denorm_min()); // ********************* QUANTITY POINT ********************* using qp_double = mp_units::quantity_point; using qp_int = mp_units::quantity_point; // cv qualifiers static_assert(std::numeric_limits::max() == qp_double::max()); static_assert(std::numeric_limits::max() == qp_double::max()); static_assert(std::numeric_limits::max() == qp_double::max()); // is_specialized static_assert(std::numeric_limits::is_specialized == true); static_assert(std::numeric_limits::is_specialized == true); // is_integer static_assert(std::numeric_limits::is_integer == false); static_assert(std::numeric_limits::is_integer == true); // has_infinity static_assert(std::numeric_limits::has_infinity == true); static_assert(std::numeric_limits::has_infinity == false); // min static_assert(std::numeric_limits::min() == qp_double::min()); static_assert(std::numeric_limits::min() == qp_int::min()); static_assert(std::numeric_limits::min().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); static_assert(std::numeric_limits::min().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); // max static_assert(std::numeric_limits::max() == qp_double::max()); static_assert(std::numeric_limits::max() == qp_int::max()); static_assert(std::numeric_limits::max().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::max()); static_assert(std::numeric_limits::max().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::max()); // lowest static_assert(std::numeric_limits::lowest().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); static_assert(std::numeric_limits::lowest().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::lowest()); // epsilon static_assert(std::numeric_limits::epsilon().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::epsilon()); static_assert(std::numeric_limits::epsilon().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::epsilon()); // round_error static_assert(std::numeric_limits::round_error().quantity_from_zero().numerical_value_in( mp_units::si::metre) == std::numeric_limits::round_error()); static_assert(std::numeric_limits::round_error().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::round_error()); // infinity static_assert(std::numeric_limits::infinity().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::infinity()); static_assert(std::numeric_limits::infinity().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::infinity()); #if MP_UNITS_HOSTED && (__cpp_lib_constexpr_cmath || MP_UNITS_COMP_GCC) // quiet_NaN static_assert( std::isnan(std::numeric_limits::quiet_NaN().quantity_from_zero().numerical_value_in(mp_units::si::metre))); // signaling_NaN static_assert(std::isnan( std::numeric_limits::signaling_NaN().quantity_from_zero().numerical_value_in(mp_units::si::metre))); #endif // denorm_min static_assert(std::numeric_limits::denorm_min().quantity_from_zero().numerical_value_in( mp_units::si::metre) == std::numeric_limits::denorm_min()); static_assert(std::numeric_limits::denorm_min().quantity_from_zero().numerical_value_in(mp_units::si::metre) == std::numeric_limits::denorm_min()); } // namespace