12#ifndef EIGEN_MPREALSUPPORT_MODULE_H
13#define EIGEN_MPREALSUPPORT_MODULE_H
15#include "../../Eigen/Core"
63struct NumTraits<mpfr::mpreal> : GenericNumTraits<mpfr::mpreal> {
68 RequireInitialization = 1,
74 typedef mpfr::mpreal Real;
75 typedef mpfr::mpreal NonInteger;
77 static inline Real highest(
long Precision = mpfr::mpreal::get_default_prec()) {
return mpfr::maxval(Precision); }
78 static inline Real lowest(
long Precision = mpfr::mpreal::get_default_prec()) {
return -mpfr::maxval(Precision); }
81 static inline Real Pi(
long Precision = mpfr::mpreal::get_default_prec()) {
return mpfr::const_pi(Precision); }
82 static inline Real Euler(
long Precision = mpfr::mpreal::get_default_prec()) {
return mpfr::const_euler(Precision); }
83 static inline Real Log2(
long Precision = mpfr::mpreal::get_default_prec()) {
return mpfr::const_log2(Precision); }
84 static inline Real Catalan(
long Precision = mpfr::mpreal::get_default_prec()) {
85 return mpfr::const_catalan(Precision);
88 static inline Real epsilon(
long Precision = mpfr::mpreal::get_default_prec()) {
89 return mpfr::machine_epsilon(Precision);
91 static inline Real epsilon(
const Real& x) {
return mpfr::machine_epsilon(x); }
93#ifdef MPREAL_HAVE_DYNAMIC_STD_NUMERIC_LIMITS
94 static inline int digits10(
long Precision = mpfr::mpreal::get_default_prec()) {
95 return std::numeric_limits<Real>::digits10(Precision);
97 static inline int digits10(
const Real& x) {
return std::numeric_limits<Real>::digits10(x); }
99 static inline int max_digits10(
long Precision = mpfr::mpreal::get_default_prec()) {
100 return std::numeric_limits<Real>::max_digits10(Precision);
103 static inline int digits() {
return std::numeric_limits<Real>::digits(); }
104 static inline int digits(
const Real& x) {
return std::numeric_limits<Real>::digits(x); }
107 static inline Real dummy_precision() {
108 mpfr_prec_t weak_prec = ((mpfr::mpreal::get_default_prec() - 1) * 90) / 100;
109 return mpfr::machine_epsilon(weak_prec);
116inline mpfr::mpreal random<mpfr::mpreal>() {
117 return mpfr::random();
121inline mpfr::mpreal random<mpfr::mpreal>(
const mpfr::mpreal& a,
const mpfr::mpreal& b) {
122 return a + (b - a) * random<mpfr::mpreal>();
125inline bool isMuchSmallerThan(
const mpfr::mpreal& a,
const mpfr::mpreal& b,
const mpfr::mpreal& eps) {
126 return mpfr::abs(a) <= mpfr::abs(b) * eps;
129inline bool isApprox(
const mpfr::mpreal& a,
const mpfr::mpreal& b,
const mpfr::mpreal& eps) {
130 return mpfr::isEqualFuzzy(a, b, eps);
133inline bool isApproxOrLessThan(
const mpfr::mpreal& a,
const mpfr::mpreal& b,
const mpfr::mpreal& eps) {
134 return a <= b || mpfr::isEqualFuzzy(a, b, eps);
138inline long double cast<mpfr::mpreal, long double>(
const mpfr::mpreal& x) {
139 return x.toLDouble();
143inline double cast<mpfr::mpreal, double>(
const mpfr::mpreal& x) {
148inline long cast<mpfr::mpreal, long>(
const mpfr::mpreal& x) {
153inline int cast<mpfr::mpreal, int>(
const mpfr::mpreal& x) {
154 return int(x.toLong());
160class gebp_traits<mpfr::mpreal, mpfr::mpreal, false, false> {
162 typedef mpfr::mpreal ResScalar;
164 Vectorizable =
false,
168 NumberOfRegisters = 1,
174 typedef ResScalar LhsPacket;
175 typedef ResScalar RhsPacket;
176 typedef ResScalar ResPacket;
177 typedef LhsPacket LhsPacket4Packing;
180template <
typename Index,
typename DataMapper,
bool ConjugateLhs,
bool ConjugateRhs>
181struct gebp_kernel<mpfr::mpreal, mpfr::mpreal,
Index, DataMapper, 1, 1, ConjugateLhs, ConjugateRhs> {
182 typedef mpfr::mpreal mpreal;
184 EIGEN_DONT_INLINE
void operator()(
const DataMapper& res,
const mpreal* blockA,
const mpreal* blockB, Index rows,
185 Index depth, Index cols,
const mpreal& alpha, Index strideA = -1,
186 Index strideB = -1, Index offsetA = 0, Index offsetB = 0) {
187 if (rows == 0 || cols == 0 || depth == 0)
return;
189 mpreal acc1(0, mpfr_get_prec(blockA[0].mpfr_srcptr())), tmp(0, mpfr_get_prec(blockA[0].mpfr_srcptr()));
191 if (strideA == -1) strideA = depth;
192 if (strideB == -1) strideB = depth;
194 for (Index i = 0; i < rows; ++i) {
195 for (Index j = 0; j < cols; ++j) {
196 const mpreal* A = blockA + i * strideA + offsetA;
197 const mpreal* B = blockB + j * strideB + offsetB;
200 for (Index k = 0; k < depth; k++) {
201 mpfr_mul(tmp.mpfr_ptr(), A[k].mpfr_srcptr(), B[k].mpfr_srcptr(), mpreal::get_default_rnd());
202 mpfr_add(acc1.mpfr_ptr(), acc1.mpfr_ptr(), tmp.mpfr_ptr(), mpreal::get_default_rnd());
205 mpfr_mul(acc1.mpfr_ptr(), acc1.mpfr_srcptr(), alpha.mpfr_srcptr(), mpreal::get_default_rnd());
206 mpfr_add(res(i, j).mpfr_ptr(), res(i, j).mpfr_srcptr(), acc1.mpfr_srcptr(), mpreal::get_default_rnd());
Namespace containing all symbols from the Eigen library.
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index