Go to the documentation of this file.
   10 #ifndef EIGEN_SPECIAL_FUNCTIONS_H 
   11 #define EIGEN_SPECIAL_FUNCTIONS_H 
   80 template <
typename Scalar, 
int N>
 
   90 template <
typename Scalar>
 
  104 template <
typename Scalar>
 
  109                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  114 template <
typename Scalar>
 
  119 #if EIGEN_HAS_C99_MATH 
  124 #if !defined(__CUDA_ARCH__) && (defined(_BSD_SOURCE) || defined(_SVID_SOURCE)) && !defined(__APPLE__) 
  126     return ::lgammaf_r(
x, &signgam);
 
  134 struct lgamma_impl<double> {
 
  137 #if !defined(__CUDA_ARCH__) && (defined(_BSD_SOURCE) || defined(_SVID_SOURCE)) && !defined(__APPLE__) 
  139     return ::lgamma_r(
x, &signgam);
 
  151 template <
typename Scalar>
 
  169 template <
typename Scalar>
 
  174                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  185       -4.16666666666666666667E-3f,
 
  186       3.96825396825396825397E-3f,
 
  187       -8.33333333333333333333E-3f,
 
  188       8.33333333333333333333E-2f
 
  204       8.33333333333333333333E-2,
 
  205       -2.10927960927960927961E-2,
 
  206       7.57575757575757575758E-3,
 
  207       -4.16666666666666666667E-3,
 
  208       3.96825396825396825397E-3,
 
  209       -8.33333333333333333333E-3,
 
  210       8.33333333333333333333E-2
 
  222 template <
typename Scalar>
 
  284     bool negative = 
false;
 
  330     return (negative) ? 
y - nz : 
y;
 
  338 template <
typename Scalar>
 
  343                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  348 template <
typename Scalar>
 
  353 #if EIGEN_HAS_C99_MATH 
  361 struct erf_impl<double> {
 
  365 #endif  // EIGEN_HAS_C99_MATH 
  371 template <
typename Scalar>
 
  376                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  381 template <
typename Scalar>
 
  386 #if EIGEN_HAS_C99_MATH 
  394 struct erfc_impl<double> {
 
  398 #endif  // EIGEN_HAS_C99_MATH 
  404 template <
typename Scalar>
 
  410 template <
typename Scalar>
 
  455 #if !EIGEN_HAS_C99_MATH 
  457 template <
typename Scalar>
 
  462                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  469 template <
typename Scalar> 
struct igamma_impl;  
 
  471 template <
typename Scalar>
 
  472 struct igammac_impl {
 
  533     if ((
x < zero) || (
a <= zero)) {
 
  538     if ((
x < one) || (
x < 
a)) {
 
  546       return (one - igamma_impl<Scalar>::Impl(
a, 
x));
 
  554   friend struct igamma_impl<
Scalar>;
 
  571     const Scalar inf = NumTraits<Scalar>::infinity();
 
  574     Scalar pk, pkm1, pkm2, qk, qkm1, qkm2;
 
  576     if (
x == inf) 
return zero;  
 
  600       pk = pkm1 * z - pkm2 * yc;
 
  601       qk = qkm1 * z - qkm2 * yc;
 
  628 #endif  // EIGEN_HAS_C99_MATH 
  634 template <
typename Scalar>
 
  639 #if !EIGEN_HAS_C99_MATH 
  641 template <
typename Scalar>
 
  646                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  653 template <
typename Scalar>
 
  721     if (
x == zero) 
return zero;
 
  723     if ((
x < zero) || (
a <= zero)) {  
 
  727     if ((
x > one) && (
x > 
a)) {
 
  735       return (one - igammac_impl<Scalar>::Impl(
a, 
x));
 
  743   friend struct igammac_impl<
Scalar>;
 
  777       if (
c/ans <= machep) {
 
  782     return (ans * ax / 
a);
 
  786 #endif  // EIGEN_HAS_C99_MATH 
  792 template <
typename Scalar>
 
  797 template <
typename Scalar>
 
  802                         THIS_TYPE_IS_NOT_SUPPORTED);
 
  832     while( (i < 9) || (
a <= 9.0) )
 
  847 template <
typename Scalar>
 
  921             Scalar(-1.8924375803183791606e9), 
 
  923             Scalar(-2.950130727918164224e12), 
 
  924             Scalar(1.1646782814350067249e14), 
 
  925             Scalar(-4.5979787224074726105e15), 
 
  926             Scalar(1.8152105401943546773e17), 
 
  927             Scalar(-7.1661652561756670113e18) 
 
  931         const Scalar zero = 0.0, 
half = 0.5, one = 1.0;
 
  973         for( i=0; i<12; i++ )
 
  996 template <
typename Scalar>
 
 1001 #if !EIGEN_HAS_C99_MATH 
 1003 template <
typename Scalar>
 
 1008                             THIS_TYPE_IS_NOT_SUPPORTED);
 
 1015 template <
typename Scalar>
 
 1016 struct polygamma_impl {
 
 1019         Scalar zero = 0.0, one = 1.0;
 
 1028         else if (
n == zero) {
 
 1039 #endif  // EIGEN_HAS_C99_MATH 
 1045 template <
typename Scalar>
 
 1050 #if !EIGEN_HAS_C99_MATH 
 1052 template <
typename Scalar>
 
 1057                         THIS_TYPE_IS_NOT_SUPPORTED);
 
 1064 template <
typename Scalar>
 
 1065 struct betainc_impl {
 
 1138                         THIS_TYPE_IS_NOT_SUPPORTED);
 
 1146 template <
typename Scalar>
 
 1147 struct incbeta_cfe {
 
 1152                         THIS_TYPE_IS_NOT_SUPPORTED);
 
 1161     Scalar xk, pk, pkm1, pkm2, qk, qkm1, qkm2;
 
 1162     Scalar k1, k2, k3, k4, k5, k6, k7, k8, k26update;
 
 1202       xk = -(
x * k1 * k2) / (k3 * k4);
 
 1203       pk = pkm1 + pkm2 * xk;
 
 1204       qk = qkm1 + qkm2 * xk;
 
 1210       xk = (
x * k5 * k6) / (k7 * k8);
 
 1211       pk = pkm1 + pkm2 * xk;
 
 1212       qk = qkm1 + qkm2 * xk;
 
 1247     } 
while (++
n < num_iters);
 
 1254 template <
typename Scalar>
 
 1255 struct betainc_helper {};
 
 1258 struct betainc_helper<float> {
 
 1262     float ans, 
a, 
b, t, 
x, onemx;
 
 1263     bool reversed_a_b = 
false;
 
 1268     if (xx > (aa / (aa + bb))) {
 
 1269       reversed_a_b = 
true;
 
 1284         t = betainc_helper<float>::incbps(
a, 
b, 
x);
 
 1285         if (reversed_a_b) t = 1.0f - t;
 
 1290     ans = 
x * (
a + 
b - 2.0f) / (
a - 1.0f);
 
 1304     if (reversed_a_b) t = 1.0f - t;
 
 1335 struct betainc_impl<float> {
 
 1337   static float run(
float a, 
float b, 
float x) {
 
 1338     const float nan = NumTraits<float>::quiet_NaN();
 
 1341     if (
a <= 0.0f) 
return nan;
 
 1342     if (
b <= 0.0f) 
return nan;
 
 1343     if ((
x <= 0.0f) || (
x >= 1.0f)) {
 
 1344       if (
x == 0.0f) 
return 0.0f;
 
 1345       if (
x == 1.0f) 
return 1.0f;
 
 1352       ans = betainc_helper<float>::incbsa(
a + 1.0f, 
b, 
x);
 
 1358       return betainc_helper<float>::incbsa(
a, 
b, 
x);
 
 1364 struct betainc_helper<double> {
 
 1369     double s, t, u, v, 
n, t1, z, ai;
 
 1380       u = (
n - 
b) * 
x / 
n;
 
 1404 struct betainc_impl<double> {
 
 1406   static double run(
double aa, 
double bb, 
double xx) {
 
 1407     const double nan = NumTraits<double>::quiet_NaN();
 
 1411     double a, 
b, t, 
x, xc, w, 
y;
 
 1412     bool reversed_a_b = 
false;
 
 1414     if (aa <= 0.0 || bb <= 0.0) {
 
 1418     if ((xx <= 0.0) || (xx >= 1.0)) {
 
 1419       if (xx == 0.0) 
return (0.0);
 
 1420       if (xx == 1.0) 
return (1.0);
 
 1425     if ((bb * xx) <= 1.0 && xx <= 0.95) {
 
 1426       return betainc_helper<double>::incbps(aa, bb, xx);
 
 1432     if (xx > (aa / (aa + bb))) {
 
 1433       reversed_a_b = 
true;
 
 1445     if (reversed_a_b && (
b * 
x) <= 1.0 && 
x <= 0.95) {
 
 1446       t = betainc_helper<double>::incbps(
a, 
b, 
x);
 
 1456     y = 
x * (
a + 
b - 2.0) - (
a - 1.0);
 
 1500 #endif  // EIGEN_HAS_C99_MATH 
 1506 template <
typename Scalar>
 
 1512 template <
typename Scalar>
 
 1518 template <
typename Scalar>
 
 1524 template <
typename Scalar>
 
 1530 template <
typename Scalar>
 
 1536 template <
typename Scalar>
 
 1542 template <
typename Scalar>
 
 1548 template <
typename Scalar>
 
 1554 template <
typename Scalar>
 
 1565 #endif  // EIGEN_SPECIAL_FUNCTIONS_H 
  
EIGEN_DEVICE_FUNC const Scalar & x
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE double biginv()
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar x, const Scalar coef[])
static EIGEN_DEVICE_FUNC Scalar run(Scalar a, Scalar x)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE TensorCwiseTernaryOp< internal::scalar_betainc_op< typename XDerived::Scalar >, const ADerived, const BDerived, const XDerived > betainc(const ADerived &a, const BDerived &b, const XDerived &x)
const EIGEN_DEVICE_FUNC ErfReturnType erf() const
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE double big()
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar)
const EIGEN_DEVICE_FUNC ErfcReturnType erfc() const
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE float big()
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE float machep()
const Eigen::CwiseBinaryOp< Eigen::internal::scalar_igammac_op< typename Derived::Scalar >, const Derived, const ExponentDerived > igammac(const Eigen::ArrayBase< Derived > &a, const Eigen::ArrayBase< ExponentDerived > &x)
static EIGEN_DEVICE_FUNC Scalar run(Scalar x)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar)
const EIGEN_DEVICE_FUNC Log1pReturnType log1p() const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE T exp(const T &x)
const EIGEN_DEVICE_FUNC DigammaReturnType digamma() const
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE float run(const float s)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE bool run(double &a, double &b, double &s, const double x, const double machep)
const EIGEN_DEVICE_FUNC LgammaReturnType lgamma() const
EIGEN_DEVICE_FUNC const Scalar & q
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(Scalar a, Scalar b, Scalar x)
#define EIGEN_STRONG_INLINE
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar big()
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar)
EIGEN_DEVICE_FUNC internal::pow_impl< ScalarX, ScalarY >::result_type pow(const ScalarX &x, const ScalarY &y)
static EIGEN_DEVICE_FUNC Scalar run(Scalar x, Scalar q)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE double machep()
const Eigen::CwiseBinaryOp< Eigen::internal::scalar_polygamma_op< typename DerivedX::Scalar >, const DerivedN, const DerivedX > polygamma(const Eigen::ArrayBase< DerivedN > &n, const Eigen::ArrayBase< DerivedX > &x)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar)
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
EIGEN_DEVICE_FUNC EIGEN_MATHFUNC_RETVAL(real, Scalar) real(const Scalar &x)
EIGEN_DEVICE_FUNC T() floor(const T &x)
const Eigen::CwiseBinaryOp< Eigen::internal::scalar_igamma_op< typename Derived::Scalar >, const Derived, const ExponentDerived > igamma(const Eigen::ArrayBase< Derived > &a, const Eigen::ArrayBase< ExponentDerived > &x)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar machep()
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(Scalar n, Scalar x)
void run(Expr &expr, Dev &dev)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(const Scalar, const Scalar coef[])
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar biginv()
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE internal::enable_if< NumTraits< T >::IsSigned||NumTraits< T >::IsComplex, typename NumTraits< T >::Real >::type abs(const T &x)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE bool run(float &a, float &b, float &s, const float x, const float machep)
MatrixType A(a, *n, *n, *lda)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE float biginv()
const Eigen::CwiseBinaryOp< Eigen::internal::scalar_zeta_op< typename DerivedX::Scalar >, const DerivedX, const DerivedQ > zeta(const Eigen::ArrayBase< DerivedX > &x, const Eigen::ArrayBase< DerivedQ > &q)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE T log(const T &x)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar run(Scalar a, Scalar x)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE T tan(const T &x)
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
EIGEN_DEVICE_FUNC const Scalar & b
#define EIGEN_MATHFUNC_IMPL(func, scalar)
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE double run(const double s)
control_box_rst
Author(s): Christoph Rösmann 
autogenerated on Wed Mar 2 2022 00:06:27