// (C) Copyright Matt Borland 2021. // Use, modification and distribution are subject to the // Boost Software License, Version 1.0. (See accompanying file // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #include #include #include #include #include #include #ifdef BOOST_HAS_FLOAT128 #include #endif // Determines if the given argument is normal, i.e. is neither zero, subnormal, infinite nor NaN. template void test() { if constexpr (std::numeric_limits::has_quiet_NaN) { static_assert(!boost::math::ccmath::isnormal(std::numeric_limits::quiet_NaN()), "Wrong response to quiet NAN"); } static_assert(!boost::math::ccmath::isnormal(T(0)), "Wrong response to 0"); if constexpr (!std::is_integral_v) { static_assert(!boost::math::ccmath::isnormal((std::numeric_limits::min)() / 2), "Wrong response to subnormal"); static_assert(!boost::math::ccmath::isnormal(std::numeric_limits::infinity()), "Wrong response to infinity"); } static_assert(boost::math::ccmath::isnormal(T(1)), "Wrong response to normal number"); } #ifndef BOOST_MATH_NO_CONSTEXPR_DETECTION int main() { test(); test(); #ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS test(); #endif #if defined(BOOST_HAS_FLOAT128) && !defined(BOOST_MATH_USING_BUILTIN_CONSTANT_P) test(); #endif test(); test(); test(); test(); test(); test(); return 0; } #else int main() { return 0; } #endif