Incorporate C++11 check into EIGEN_HAS_C99_MATH macro

This commit is contained in:
Deanna Hood 2015-04-20 14:57:04 -04:00
parent 0250f4a9f2
commit 249c48ba00
2 changed files with 24 additions and 38 deletions

View File

@ -804,26 +804,18 @@ bool (isfinite)(const std::complex<T>& x)
using std::imag;
return isfinite(real(x)) && isfinite(imag(x));
}
#import <iostream>
// Let's be conservative and enable the std::isnan implementation only if we are sure it exists
#if (__cplusplus >= 201103L) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC) \
&& (EIGEN_ARCH_i386_OR_x86_64) && (EIGEN_OS_GNULINUX || EIGEN_OS_WIN_STRICT || EIGEN_OS_MAC) \
|| defined(EIGEN_HAS_C99_MATH)
template<typename T>
EIGEN_DEVICE_FUNC
bool (isNaN)(const T& x)
{
template<typename T>
EIGEN_DEVICE_FUNC
bool (isNaN)(const T& x)
{
#ifdef EIGEN_HAS_C99_MATH
using std::isnan;
return isnan(x);
}
#else
template<typename T>
EIGEN_DEVICE_FUNC
bool (isNaN)(const T& x)
{
return x == x;
}
#endif
#else
return x != x;
#endif
}
template<typename T>
EIGEN_DEVICE_FUNC
@ -835,25 +827,17 @@ bool (isNaN)(const std::complex<T>& x)
return isnan(real(x)) || isnan(imag(x));
}
// Let's be conservative and enable the std::isinf implementation only if we are sure it exists
#if (__cplusplus >= 201103L) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC) \
&& (EIGEN_ARCH_i386_OR_x86_64) && (EIGEN_OS_GNULINUX || EIGEN_OS_WIN_STRICT || EIGEN_OS_MAC) \
|| defined(EIGEN_HAS_C99_MATH)
template<typename T>
EIGEN_DEVICE_FUNC
bool (isInf)(const T& x)
{
template<typename T>
EIGEN_DEVICE_FUNC
bool (isInf)(const T& x)
{
#ifdef EIGEN_HAS_C99_MATH
using std::isinf;
return isinf(x);
}
#else
template<typename T>
EIGEN_DEVICE_FUNC
bool (isInf)(const T& x)
{
#else
return x>NumTraits<T>::highest() || x<NumTraits<T>::lowest();
}
#endif
#endif
}
template<typename T>
EIGEN_DEVICE_FUNC

View File

@ -403,10 +403,12 @@
#endif
// Does the compiler support C99 math?
#if (EIGEN_COMP_GNUC_STRICT || \
(EIGEN_COMP_ICC && EIGEN_COMP_GNUC) || \
(EIGEN_COMP_CLANG) || \
(EIGEN_COMP_MSVC >= 1800))
#if (__cplusplus >= 201103L) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC) \
&& (EIGEN_ARCH_i386_OR_x86_64) && (EIGEN_OS_GNULINUX || EIGEN_OS_WIN_STRICT || EIGEN_OS_MAC) || \
(EIGEN_COMP_GNUC_STRICT || \
(EIGEN_COMP_ICC && EIGEN_COMP_GNUC) || \
(EIGEN_COMP_CLANG) || \
(EIGEN_COMP_MSVC >= 1800))
#define EIGEN_HAS_C99_MATH 1
#endif