10 #ifndef EIGEN_NUMTRAITS_H 11 #define EIGEN_NUMTRAITS_H 20 bool use_numeric_limits = std::numeric_limits<T>::is_specialized,
21 bool is_integer = NumTraits<T>::IsInteger>
22 struct default_digits10_impl
24 static int run() {
return std::numeric_limits<T>::digits10; }
28 struct default_digits10_impl<T,false,false>
33 typedef typename NumTraits<T>::Real Real;
34 return int(
ceil(-
log10(NumTraits<Real>::epsilon())));
39 struct default_digits10_impl<T,false,true>
41 static int run() {
return 0; }
88 template<
typename T>
struct GenericNumTraits
91 IsInteger = std::numeric_limits<T>::is_integer,
92 IsSigned = std::numeric_limits<T>::is_signed,
94 RequireInitialization = internal::is_arithmetic<T>::value ? 0 : 1,
103 template<
bool Vectorized>
106 #ifdef EIGEN_VECTORIZE_AVX 111 Cost = IsInteger ? (
sizeof(T) == 8 ? (IsSigned ? 24 : 21) : (IsSigned ? 8 : 9)):
112 Vectorized ? (sizeof(T) == 8 ? (AVX ? 16 : 8) : (AVX ? 14 : 7)) : 8
118 typedef typename internal::conditional<
120 typename internal::conditional<sizeof(T)<=2, float, double>::type,
127 static inline Real epsilon()
129 return numext::numeric_limits<T>::epsilon();
133 static inline int digits10()
135 return internal::default_digits10_impl<T>::run();
139 static inline Real dummy_precision()
147 static inline T highest() {
148 return (numext::numeric_limits<T>::max)();
152 static inline T lowest() {
153 return IsInteger ? (numext::numeric_limits<T>::min)() : (-(numext::numeric_limits<T>::max)());
157 static inline T infinity() {
158 return numext::numeric_limits<T>::infinity();
162 static inline T quiet_NaN() {
163 return numext::numeric_limits<T>::quiet_NaN();
167 template<
typename T>
struct NumTraits : GenericNumTraits<T>
171 : GenericNumTraits<float>
174 static inline float dummy_precision() {
return 1e-5f; }
177 template<>
struct NumTraits<double> : GenericNumTraits<double>
180 static inline double dummy_precision() {
return 1e-12; }
184 : GenericNumTraits<long double>
186 static inline long double dummy_precision() {
return 1e-15l; }
189 template<
typename _Real>
struct NumTraits<std::complex<_Real> >
190 : GenericNumTraits<std::complex<_Real> >
210 template<
typename Scalar,
int Rows,
int Cols,
int Options,
int MaxRows,
int MaxCols>
211 struct NumTraits<Array<Scalar, Rows, Cols, Options, MaxRows, MaxCols> >
218 typedef ArrayType & Nested;
225 RequireInitialization = 1,
238 : GenericNumTraits<std::string>
241 RequireInitialization = 1,
247 static inline int digits10() {
return 0; }
250 static inline std::string epsilon();
251 static inline std::string dummy_precision();
252 static inline std::string lowest();
253 static inline std::string highest();
254 static inline std::string infinity();
255 static inline std::string quiet_NaN();
260 #endif // EIGEN_NUMTRAITS_H const int HugeCost
Definition: Constants.h:39
Namespace containing all symbols from the Eigen library.
Definition: Core:271
Holds information about the various numeric (i.e. scalar) types allowed by Eigen. ...
Definition: NumTraits.h:167
const Eigen::CwiseUnaryOp< Eigen::internal::scalar_ceil_op< typename Derived::Scalar >, const Derived > ceil(const Eigen::ArrayBase< Derived > &x)
Definition: Eigen_Colamd.h:50
General-purpose arrays with easy API for coefficient-wise operations.
Definition: Array.h:45
const int Dynamic
Definition: Constants.h:21
const Eigen::CwiseUnaryOp< Eigen::internal::scalar_log10_op< typename Derived::Scalar >, const Derived > log10(const Eigen::ArrayBase< Derived > &x)