Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / libcxx / include / __math / gamma.h
blob693e111a84e99dfa1197cc6d2ed81ce0edcbdb86
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #ifndef _LIBCPP___MATH_GAMMA_H
10 #define _LIBCPP___MATH_GAMMA_H
12 #include <__config>
13 #include <__type_traits/enable_if.h>
14 #include <__type_traits/is_integral.h>
16 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
17 # pragma GCC system_header
18 #endif
20 _LIBCPP_BEGIN_NAMESPACE_STD
22 namespace __math {
24 // lgamma
26 inline _LIBCPP_HIDE_FROM_ABI float lgamma(float __x) _NOEXCEPT { return __builtin_lgammaf(__x); }
28 template <class = int>
29 _LIBCPP_HIDE_FROM_ABI double lgamma(double __x) _NOEXCEPT {
30 return __builtin_lgamma(__x);
33 inline _LIBCPP_HIDE_FROM_ABI long double lgamma(long double __x) _NOEXCEPT { return __builtin_lgammal(__x); }
35 template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0>
36 inline _LIBCPP_HIDE_FROM_ABI double lgamma(_A1 __x) _NOEXCEPT {
37 return __builtin_lgamma((double)__x);
40 // nan
42 // tgamma
44 inline _LIBCPP_HIDE_FROM_ABI float tgamma(float __x) _NOEXCEPT { return __builtin_tgammaf(__x); }
46 template <class = int>
47 _LIBCPP_HIDE_FROM_ABI double tgamma(double __x) _NOEXCEPT {
48 return __builtin_tgamma(__x);
51 inline _LIBCPP_HIDE_FROM_ABI long double tgamma(long double __x) _NOEXCEPT { return __builtin_tgammal(__x); }
53 template <class _A1, __enable_if_t<is_integral<_A1>::value, int> = 0>
54 inline _LIBCPP_HIDE_FROM_ABI double tgamma(_A1 __x) _NOEXCEPT {
55 return __builtin_tgamma((double)__x);
58 } // namespace __math
60 _LIBCPP_END_NAMESPACE_STD
62 #endif // _LIBCPP___MATH_GAMMA_H