E.V.E
v2023.02.15
Loading...
Searching...
No Matches
◆
stirling
eve::stirling = functor<stirling_t>
inline
constexpr
Header file
#include <eve/module/special.hpp>
Callable Signatures
namespace
eve
{
// Regular overload
constexpr
auto
stirling
(
floating_value
auto
x
)
noexcept
;
// 1
// Lanes masking
constexpr
auto
stirling
[
conditional_expr
auto
c
](
floating_value
auto
x
)
noexcept
;
// 2
constexpr
auto
stirling
[
logical_value
auto
m
](
floating_value
auto
x
)
noexcept
;
// 2
}
eve::conditional_expr
Specifies that a type is a Conditional Expression.
Definition
conditional.hpp:28
eve::floating_value
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition
value.hpp:116
eve::logical_value
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition
value.hpp:134
eve::stirling
constexpr auto stirling
elementwise_callable object computing the Stirling approximation of the function.
Definition
stirling.hpp:73
eve::translate_t
typename decltype(detail::as_translated_type(as< T >{}))::type translate_t
Returns the final translated type of T.
Definition
translation.hpp:107
eve
EVE Main Namespace.
Definition
abi.hpp:19
Parameters
x
:
floating value
.
c
:
Conditional expression
masking the operation.
m
:
Logical value
masking the operation.
Return value
The value of an approximation of the \(\Gamma\) function by \(\displaystyle \Gamma(x) \approx \sqrt{2 \pi} x^{x-\frac12} e^{-x} \left( 1 + \frac1{x} P(\frac1{x})\right)\), where \(P\) is a polynomial, is returned.
The operation is performed conditionnaly
.
External references
Wikipedia: Stirling approximation
Wolfram MathWorld: Stirling's Approximation
Example
// revision 1
#include <eve/module/special.hpp>
#include <iostream>
int
main
()
{
eve::wide<float>
wf
([](
auto
i,
auto
c
)->
float
{
return
2*(i+
float
(
c
)/3);});
std::cout <<
"<- wf = "
<<
wf
<<
"\n"
;
std::cout <<
"-> stirling(wf) = "
<<
eve::stirling
(
wf
) <<
"\n"
;
std::cout <<
"-> stirling[ignore_last(2)](wf)= "
<<
eve::stirling
[
eve::ignore_last
(2)](
wf
) <<
"\n"
;
std::cout <<
"-> stirling[wf != 6.0f](wf) = "
<<
eve::stirling
[
wf
!= 6.0f](
wf
) <<
"\n"
;
}
eve::ignore_last
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition
conditional.hpp:320
eve