Wire Sysio Wire Sysion 1.0.0
Loading...
Searching...
No Matches
internal::Double Class Reference

#include <ieee754.h>

Collaboration diagram for internal::Double:

Public Member Functions

 Double ()
 
 Double (double d)
 
 Double (uint64_t u)
 
double Value () const
 
uint64_t Uint64Value () const
 
double NextPositiveDouble () const
 
bool Sign () const
 
uint64_t Significand () const
 
int Exponent () const
 
bool IsNan () const
 
bool IsInf () const
 
bool IsNanOrInf () const
 
bool IsNormal () const
 
bool IsZero () const
 
uint64_t IntegerSignificand () const
 
int IntegerExponent () const
 
uint64_t ToBias () const
 

Static Public Member Functions

static int EffectiveSignificandSize (int order)
 

Detailed Description

Definition at line 23 of file ieee754.h.

Constructor & Destructor Documentation

◆ Double() [1/3]

internal::Double::Double ( )
inline

Definition at line 25 of file ieee754.h.

25{}
Here is the caller graph for this function:

◆ Double() [2/3]

internal::Double::Double ( double d)
inline

Definition at line 26 of file ieee754.h.

26: d_(d) {}

◆ Double() [3/3]

internal::Double::Double ( uint64_t u)
inline

Definition at line 27 of file ieee754.h.

27: u_(u) {}
uint64_t u_
Definition ieee754.h:71

Member Function Documentation

◆ EffectiveSignificandSize()

static int internal::Double::EffectiveSignificandSize ( int order)
inlinestatic

Definition at line 51 of file ieee754.h.

51 {
52 if (order >= -1021)
53 return 53;
54 else if (order <= -1074)
55 return 0;
56 else
57 return order + 1074;
58 }
Here is the caller graph for this function:

◆ Exponent()

int internal::Double::Exponent ( ) const
inline

Definition at line 39 of file ieee754.h.

39{ return static_cast<int>(((u_ & kExponentMask) >> kSignificandSize) - kExponentBias); }
Here is the caller graph for this function:

◆ IntegerExponent()

int internal::Double::IntegerExponent ( ) const
inline

Definition at line 48 of file ieee754.h.

48{ return (IsNormal() ? Exponent() : kDenormalExponent) - kSignificandSize; }
bool IsNormal() const
Definition ieee754.h:44
int Exponent() const
Definition ieee754.h:39
Here is the call graph for this function:
Here is the caller graph for this function:

◆ IntegerSignificand()

uint64_t internal::Double::IntegerSignificand ( ) const
inline

Definition at line 47 of file ieee754.h.

47{ return IsNormal() ? Significand() | kHiddenBit : Significand(); }
uint64_t Significand() const
Definition ieee754.h:38
Here is the call graph for this function:
Here is the caller graph for this function:

◆ IsInf()

bool internal::Double::IsInf ( ) const
inline

Definition at line 42 of file ieee754.h.

42{ return (u_ & kExponentMask) == kExponentMask && Significand() == 0; }
Here is the call graph for this function:
Here is the caller graph for this function:

◆ IsNan()

bool internal::Double::IsNan ( ) const
inline

Definition at line 41 of file ieee754.h.

41{ return (u_ & kExponentMask) == kExponentMask && Significand() != 0; }
Here is the call graph for this function:
Here is the caller graph for this function:

◆ IsNanOrInf()

bool internal::Double::IsNanOrInf ( ) const
inline

Definition at line 43 of file ieee754.h.

43{ return (u_ & kExponentMask) == kExponentMask; }

◆ IsNormal()

bool internal::Double::IsNormal ( ) const
inline

Definition at line 44 of file ieee754.h.

44{ return (u_ & kExponentMask) != 0 || Significand() == 0; }
Here is the call graph for this function:
Here is the caller graph for this function:

◆ IsZero()

bool internal::Double::IsZero ( ) const
inline

Definition at line 45 of file ieee754.h.

45{ return (u_ & (kExponentMask | kSignificandMask)) == 0; }

◆ NextPositiveDouble()

double internal::Double::NextPositiveDouble ( ) const
inline

Definition at line 32 of file ieee754.h.

32 {
34 return Double(u_ + 1).Value();
35 }
bool Sign() const
Definition ieee754.h:37
#define RAPIDJSON_ASSERT(x)
Assertion.
Definition rapidjson.h:406
Here is the call graph for this function:

◆ Sign()

bool internal::Double::Sign ( ) const
inline

Definition at line 37 of file ieee754.h.

37{ return (u_ & kSignMask) != 0; }
Here is the caller graph for this function:

◆ Significand()

uint64_t internal::Double::Significand ( ) const
inline

Definition at line 38 of file ieee754.h.

38{ return u_ & kSignificandMask; }
Here is the caller graph for this function:

◆ ToBias()

uint64_t internal::Double::ToBias ( ) const
inline

Definition at line 49 of file ieee754.h.

49{ return (u_ & kSignMask) ? ~u_ + 1 : u_ | kSignMask; }
Here is the caller graph for this function:

◆ Uint64Value()

uint64_t internal::Double::Uint64Value ( ) const
inline

Definition at line 30 of file ieee754.h.

30{ return u_; }

◆ Value()

double internal::Double::Value ( ) const
inline

Definition at line 29 of file ieee754.h.

29{ return d_; }
Here is the caller graph for this function:

Member Data Documentation

◆ d_

double internal::Double::d_

Definition at line 70 of file ieee754.h.

◆ u_

uint64_t internal::Double::u_

Definition at line 71 of file ieee754.h.


The documentation for this class was generated from the following file: