Float
-
class HPS::Float
The Float class is a concept class that exposes a number of useful utilities for working with floating point numbers.
Public Static Functions
- static inline HPS_INLINE void apply_sign_bit (double &a, uint32_t const &sign_bit)
- static inline HPS_INLINE void apply_sign_bit (float &a, uint32_t const &sign_bit)
- static inline HPS_INLINE float C2F (unsigned char x)
- static HPS_INLINE bool Equals (double const &a, double const &b, int tolerance=default_tolerance)
- static HPS_INLINE bool Equals (float const &a, float const &b, int tolerance=default_tolerance)
- template<typename Alloc> static inline HPS_INLINE bool Equals (std::vector< float, Alloc > const &a, std::vector< float, Alloc > const &b, int tolerance=32)
- static inline HPS_INLINE uint32_t extract_sign_bit (double const &a)
- static inline HPS_INLINE uint32_t extract_sign_bit (float const &a)
- static inline HPS_INLINE uint32_t extract_uint32_t (float const &a)
- static inline HPS_INLINE void inject_uint32_t (float &a, uint32_t const &i)
- static inline HPS_INLINE bool IsAbnormal (double const &a)
- static inline HPS_INLINE bool IsAbnormal (float const &a)
See if the value is not “normal” (infinite or NaN)
- static inline HPS_INLINE bool IsInfinite (double const &a)
- static inline HPS_INLINE bool IsInfinite (float const &a)
See if the value is either infinity
- static inline HPS_INLINE bool IsNAN (double const &a)
- static inline HPS_INLINE bool IsNAN (float const &a)
See if the value is Not-A-Number
- static inline HPS_INLINE bool match (double const &a, double const &b)
- static inline HPS_INLINE bool match (float const &a, float const &b)
- static inline HPS_INLINE void pack_4 (float const &f, float *m)
- static inline HPS_INLINE void pack_4 (float const &f0, float const &f1, float const &f2, float const &f3, float *m)
- static inline HPS_INLINE void replace_if_larger (double &a, double const &b)
- static inline HPS_INLINE void replace_if_larger (float &a, float const &b)
- static inline HPS_INLINE void replace_if_smaller (double &a, double const &b)
- static inline HPS_INLINE void replace_if_smaller (float &a, float const &b)
- static inline HPS_INLINE unsigned char unit_to_byte (float const &a)
- static inline HPS_INLINE unsigned char unit_to_byte_scaled (float const &a, unsigned char mix)
- static inline HPS_INLINE void unpack_4 (float &f0, float &f1, float &f2, float &f3, float const *const m)
- static inline HPS_INLINE void unpack_4 (float *f0, float const *const m)
Public Static Attributes
-
static constexpr int default_tolerance = 32
Checks two floats for equality within a specified tolerance. The tolerance is specified in float increments that scale with the floats themselves.
-
static float const Infinity
The 32-bit float representation of infinity.
-
static float const NegativeInfinity
The 32-bit float representation of negative infinity.