1e78f53d1SNikolas Klauser //===----------------------------------------------------------------------===// 2e78f53d1SNikolas Klauser // 3e78f53d1SNikolas Klauser // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4e78f53d1SNikolas Klauser // See https://llvm.org/LICENSE.txt for license information. 5e78f53d1SNikolas Klauser // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6e78f53d1SNikolas Klauser // 7e78f53d1SNikolas Klauser //===----------------------------------------------------------------------===// 8e78f53d1SNikolas Klauser 9*ce777190SNikolas Klauser #ifndef _LIBCPP___CXX03___MATH_EXPONENTIAL_FUNCTIONS_H 10*ce777190SNikolas Klauser #define _LIBCPP___CXX03___MATH_EXPONENTIAL_FUNCTIONS_H 11e78f53d1SNikolas Klauser 1273fbae83SNikolas Klauser #include <__cxx03/__config> 1373fbae83SNikolas Klauser #include <__cxx03/__type_traits/enable_if.h> 1473fbae83SNikolas Klauser #include <__cxx03/__type_traits/is_arithmetic.h> 1573fbae83SNikolas Klauser #include <__cxx03/__type_traits/is_integral.h> 1673fbae83SNikolas Klauser #include <__cxx03/__type_traits/is_same.h> 1773fbae83SNikolas Klauser #include <__cxx03/__type_traits/promote.h> 18e78f53d1SNikolas Klauser 19e78f53d1SNikolas Klauser #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 20e78f53d1SNikolas Klauser # pragma GCC system_header 21e78f53d1SNikolas Klauser #endif 22e78f53d1SNikolas Klauser 23e78f53d1SNikolas Klauser _LIBCPP_BEGIN_NAMESPACE_STD 24e78f53d1SNikolas Klauser 25e78f53d1SNikolas Klauser namespace __math { 26e78f53d1SNikolas Klauser 27e78f53d1SNikolas Klauser // exp 28e78f53d1SNikolas Klauser 29e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float exp(float __x) _NOEXCEPT { return __builtin_expf(__x); } 30e78f53d1SNikolas Klauser 31e78f53d1SNikolas Klauser template <class = int> 32e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double exp(double __x) _NOEXCEPT { 33e78f53d1SNikolas Klauser return __builtin_exp(__x); 34e78f53d1SNikolas Klauser } 35e78f53d1SNikolas Klauser 36e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double exp(long double __x) _NOEXCEPT { return __builtin_expl(__x); } 37e78f53d1SNikolas Klauser 38e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 39e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double exp(_A1 __x) _NOEXCEPT { 40e78f53d1SNikolas Klauser return __builtin_exp((double)__x); 41e78f53d1SNikolas Klauser } 42e78f53d1SNikolas Klauser 43e78f53d1SNikolas Klauser // frexp 44e78f53d1SNikolas Klauser 45e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float frexp(float __x, int* __e) _NOEXCEPT { return __builtin_frexpf(__x, __e); } 46e78f53d1SNikolas Klauser 47e78f53d1SNikolas Klauser template <class = int> 48e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double frexp(double __x, int* __e) _NOEXCEPT { 49e78f53d1SNikolas Klauser return __builtin_frexp(__x, __e); 50e78f53d1SNikolas Klauser } 51e78f53d1SNikolas Klauser 52e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double frexp(long double __x, int* __e) _NOEXCEPT { 53e78f53d1SNikolas Klauser return __builtin_frexpl(__x, __e); 54e78f53d1SNikolas Klauser } 55e78f53d1SNikolas Klauser 56e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 57e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double frexp(_A1 __x, int* __e) _NOEXCEPT { 58e78f53d1SNikolas Klauser return __builtin_frexp((double)__x, __e); 59e78f53d1SNikolas Klauser } 60e78f53d1SNikolas Klauser 61e78f53d1SNikolas Klauser // ldexp 62e78f53d1SNikolas Klauser 63e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float ldexp(float __x, int __e) _NOEXCEPT { return __builtin_ldexpf(__x, __e); } 64e78f53d1SNikolas Klauser 65e78f53d1SNikolas Klauser template <class = int> 66e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double ldexp(double __x, int __e) _NOEXCEPT { 67e78f53d1SNikolas Klauser return __builtin_ldexp(__x, __e); 68e78f53d1SNikolas Klauser } 69e78f53d1SNikolas Klauser 70e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double ldexp(long double __x, int __e) _NOEXCEPT { 71e78f53d1SNikolas Klauser return __builtin_ldexpl(__x, __e); 72e78f53d1SNikolas Klauser } 73e78f53d1SNikolas Klauser 74e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 75e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double ldexp(_A1 __x, int __e) _NOEXCEPT { 76e78f53d1SNikolas Klauser return __builtin_ldexp((double)__x, __e); 77e78f53d1SNikolas Klauser } 78e78f53d1SNikolas Klauser 79e78f53d1SNikolas Klauser // exp2 80e78f53d1SNikolas Klauser 81e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float exp2(float __x) _NOEXCEPT { return __builtin_exp2f(__x); } 82e78f53d1SNikolas Klauser 83e78f53d1SNikolas Klauser template <class = int> 84e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double exp2(double __x) _NOEXCEPT { 85e78f53d1SNikolas Klauser return __builtin_exp2(__x); 86e78f53d1SNikolas Klauser } 87e78f53d1SNikolas Klauser 88e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double exp2(long double __x) _NOEXCEPT { return __builtin_exp2l(__x); } 89e78f53d1SNikolas Klauser 90e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 91e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double exp2(_A1 __x) _NOEXCEPT { 92e78f53d1SNikolas Klauser return __builtin_exp2((double)__x); 93e78f53d1SNikolas Klauser } 94e78f53d1SNikolas Klauser 95e78f53d1SNikolas Klauser // expm1 96e78f53d1SNikolas Klauser 97e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float expm1(float __x) _NOEXCEPT { return __builtin_expm1f(__x); } 98e78f53d1SNikolas Klauser 99e78f53d1SNikolas Klauser template <class = int> 100e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double expm1(double __x) _NOEXCEPT { 101e78f53d1SNikolas Klauser return __builtin_expm1(__x); 102e78f53d1SNikolas Klauser } 103e78f53d1SNikolas Klauser 104e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double expm1(long double __x) _NOEXCEPT { return __builtin_expm1l(__x); } 105e78f53d1SNikolas Klauser 106e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 107e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double expm1(_A1 __x) _NOEXCEPT { 108e78f53d1SNikolas Klauser return __builtin_expm1((double)__x); 109e78f53d1SNikolas Klauser } 110e78f53d1SNikolas Klauser 111e78f53d1SNikolas Klauser // scalbln 112e78f53d1SNikolas Klauser 113e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float scalbln(float __x, long __y) _NOEXCEPT { return __builtin_scalblnf(__x, __y); } 114e78f53d1SNikolas Klauser 115e78f53d1SNikolas Klauser template <class = int> 116e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double scalbln(double __x, long __y) _NOEXCEPT { 117e78f53d1SNikolas Klauser return __builtin_scalbln(__x, __y); 118e78f53d1SNikolas Klauser } 119e78f53d1SNikolas Klauser 120e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double scalbln(long double __x, long __y) _NOEXCEPT { 121e78f53d1SNikolas Klauser return __builtin_scalblnl(__x, __y); 122e78f53d1SNikolas Klauser } 123e78f53d1SNikolas Klauser 124e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 125e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double scalbln(_A1 __x, long __y) _NOEXCEPT { 126e78f53d1SNikolas Klauser return __builtin_scalbln((double)__x, __y); 127e78f53d1SNikolas Klauser } 128e78f53d1SNikolas Klauser 129e78f53d1SNikolas Klauser // scalbn 130e78f53d1SNikolas Klauser 131e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float scalbn(float __x, int __y) _NOEXCEPT { return __builtin_scalbnf(__x, __y); } 132e78f53d1SNikolas Klauser 133e78f53d1SNikolas Klauser template <class = int> 134e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double scalbn(double __x, int __y) _NOEXCEPT { 135e78f53d1SNikolas Klauser return __builtin_scalbn(__x, __y); 136e78f53d1SNikolas Klauser } 137e78f53d1SNikolas Klauser 138e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double scalbn(long double __x, int __y) _NOEXCEPT { 139e78f53d1SNikolas Klauser return __builtin_scalbnl(__x, __y); 140e78f53d1SNikolas Klauser } 141e78f53d1SNikolas Klauser 142e78f53d1SNikolas Klauser template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0> 143e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI double scalbn(_A1 __x, int __y) _NOEXCEPT { 144e78f53d1SNikolas Klauser return __builtin_scalbn((double)__x, __y); 145e78f53d1SNikolas Klauser } 146e78f53d1SNikolas Klauser 147e78f53d1SNikolas Klauser // pow 148e78f53d1SNikolas Klauser 149e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI float pow(float __x, float __y) _NOEXCEPT { return __builtin_powf(__x, __y); } 150e78f53d1SNikolas Klauser 151e78f53d1SNikolas Klauser template <class = int> 152e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI double pow(double __x, double __y) _NOEXCEPT { 153e78f53d1SNikolas Klauser return __builtin_pow(__x, __y); 154e78f53d1SNikolas Klauser } 155e78f53d1SNikolas Klauser 156e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI long double pow(long double __x, long double __y) _NOEXCEPT { 157e78f53d1SNikolas Klauser return __builtin_powl(__x, __y); 158e78f53d1SNikolas Klauser } 159e78f53d1SNikolas Klauser 160e78f53d1SNikolas Klauser template <class _A1, class _A2, __enable_if_t<is_arithmetic<_A1>::value && is_arithmetic<_A2>::value, int> = 0> 161e78f53d1SNikolas Klauser inline _LIBCPP_HIDE_FROM_ABI typename __promote<_A1, _A2>::type pow(_A1 __x, _A2 __y) _NOEXCEPT { 162e78f53d1SNikolas Klauser using __result_type = typename __promote<_A1, _A2>::type; 163e78f53d1SNikolas Klauser static_assert(!(_IsSame<_A1, __result_type>::value && _IsSame<_A2, __result_type>::value), ""); 164e78f53d1SNikolas Klauser return __math::pow((__result_type)__x, (__result_type)__y); 165e78f53d1SNikolas Klauser } 166e78f53d1SNikolas Klauser 167e78f53d1SNikolas Klauser } // namespace __math 168e78f53d1SNikolas Klauser 169e78f53d1SNikolas Klauser _LIBCPP_END_NAMESPACE_STD 170e78f53d1SNikolas Klauser 171*ce777190SNikolas Klauser #endif // _LIBCPP___CXX03___MATH_EXPONENTIAL_FUNCTIONS_H 172