diff options
author | Gael Guennebaud <g.gael@free.fr> | 2018-11-26 16:36:19 +0100 |
---|---|---|
committer | Gael Guennebaud <g.gael@free.fr> | 2018-11-26 16:36:19 +0100 |
commit | cf8b85d5c5d1896ce1759a8c18beb56e8a71dea2 (patch) | |
tree | 4a441562f5ceb7d93b75518564cf42ac7b22a347 /Eigen/src/Core/GenericPacketMath.h | |
parent | c2f35b1b4763348fd0a6df2ce750a7d3d3a56d79 (diff) |
Unify SSE and AVX implementation of pexp
Diffstat (limited to 'Eigen/src/Core/GenericPacketMath.h')
-rw-r--r-- | Eigen/src/Core/GenericPacketMath.h | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/Eigen/src/Core/GenericPacketMath.h b/Eigen/src/Core/GenericPacketMath.h index 316b03f96..e8e7fa4d3 100644 --- a/Eigen/src/Core/GenericPacketMath.h +++ b/Eigen/src/Core/GenericPacketMath.h @@ -220,6 +220,12 @@ pandnot(const Packet& a, const Packet& b) { return a & (!b); } template<typename Packet> EIGEN_DEVICE_FUNC inline Packet pfrexp(const Packet &a, Packet &exponent) { return std::frexp(a,&exponent); } +/** \internal \returns a * 2^exponent + * See https://en.cppreference.com/w/cpp/numeric/math/ldexp + */ +template<typename Packet> EIGEN_DEVICE_FUNC inline Packet +pldexp(const Packet &a, const Packet &exponent) { return std::ldexp(a,exponent); } + /** \internal \returns zeros */ template<typename Packet> EIGEN_DEVICE_FUNC inline Packet pzero(const Packet& a) { return pxor(a,a); } @@ -656,6 +662,23 @@ pfrexp_float(const Packet& a, Packet& exponent) { return por(pand(a, cst_inv_mant_mask), cst_half); } +/** \internal shift the bits by n and cast the result to the initial type, i.e.: + * return reinterpret_cast<float>(int(a) >> n) + */ +template<typename Packet> EIGEN_DEVICE_FUNC inline Packet +pcast_and_shiftleft(Packet a, int n); + +/** Default implementation of pldexp for float. + * It is expected to be called by implementers of template<> pldexp, + * and the above pcast_and_shiftleft function must be implemented. + */ +template<typename Packet> EIGEN_STRONG_INLINE Packet +pldexp_float(Packet a, Packet exponent) { + const Packet cst_127 = pset1<Packet>(127.f); + // return a * 2^exponent + return pmul(a, pcast_and_shiftleft(padd(exponent, cst_127), 23)); +} + } // end namespace internal } // end namespace Eigen |