LLVM 22.0.0git
llvm::detail::IEEEFloat Class Referencefinal

#include "llvm/ADT/APFloat.h"

Public Member Functions

bool needsCleanup () const
 Returns whether this instance allocated memory.
bool operator== (const IEEEFloat &) const =delete
 The definition of equality is not straightforward for floating point, so we won't use operator==.
LLVM_ABI cmpResult compare (const IEEEFloat &) const
 IEEE comparison with another floating point number (NaNs compare unordered, 0==-0).
LLVM_ABI bool bitwiseIsEqual (const IEEEFloat &) const
 Bitwise comparison for equality (QNaNs compare equal, 0!=-0).
LLVM_ABI unsigned int convertToHexString (char *dst, unsigned int hexDigits, bool upperCase, roundingMode) const
 Write out a hexadecimal representation of the floating point value to DST, which must be of sufficient size, in the C99 form [-]0xh.hhhhp[+-]d.
LLVM_ABI IEEEFloatoperator= (const IEEEFloat &)
LLVM_ABI IEEEFloatoperator= (IEEEFloat &&)
LLVM_ABI void toString (SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
 Converts this value into a decimal string.
LLVM_ABI LLVM_READONLY int getExactLog2Abs () const
LLVM_ABI cmpResult compareAbsoluteValue (const IEEEFloat &) const
Constructors
LLVM_ABI IEEEFloat (const fltSemantics &)
LLVM_ABI IEEEFloat (const fltSemantics &, integerPart)
LLVM_ABI IEEEFloat (const fltSemantics &, uninitializedTag)
LLVM_ABI IEEEFloat (const fltSemantics &, const APInt &)
LLVM_ABI IEEEFloat (double d)
LLVM_ABI IEEEFloat (float f)
LLVM_ABI IEEEFloat (const IEEEFloat &)
LLVM_ABI IEEEFloat (IEEEFloat &&)
LLVM_ABI ~IEEEFloat ()
Arithmetic
LLVM_ABI opStatus add (const IEEEFloat &, roundingMode)
LLVM_ABI opStatus subtract (const IEEEFloat &, roundingMode)
LLVM_ABI opStatus multiply (const IEEEFloat &, roundingMode)
LLVM_ABI opStatus divide (const IEEEFloat &, roundingMode)
LLVM_ABI opStatus remainder (const IEEEFloat &)
 IEEE remainder.
LLVM_ABI opStatus mod (const IEEEFloat &)
 C fmod, or llvm frem.
LLVM_ABI opStatus fusedMultiplyAdd (const IEEEFloat &, const IEEEFloat &, roundingMode)
LLVM_ABI opStatus roundToIntegral (roundingMode)
LLVM_ABI opStatus next (bool nextDown)
 IEEE-754R 5.3.1: nextUp/nextDown.
Sign operations.
LLVM_ABI void changeSign ()
Conversions
LLVM_ABI opStatus convert (const fltSemantics &, roundingMode, bool *)
 IEEEFloat::convert - convert a value of one floating point type to another.
LLVM_ABI opStatus convertToInteger (MutableArrayRef< integerPart >, unsigned int, bool, roundingMode, bool *) const
LLVM_ABI opStatus convertFromAPInt (const APInt &, bool, roundingMode)
LLVM_ABI Expected< opStatusconvertFromString (StringRef, roundingMode)
LLVM_ABI APInt bitcastToAPInt () const
LLVM_ABI double convertToDouble () const
LLVM_ABI float convertToFloat () const
IEEE-754R 5.7.2 General operations.
bool isNegative () const
 IEEE-754R isSignMinus: Returns true if and only if the current value is negative.
bool isNormal () const
 IEEE-754R isNormal: Returns true if and only if the current value is normal.
bool isFinite () const
 Returns true if and only if the current value is zero, subnormal, or normal.
bool isZero () const
 Returns true if and only if the float is plus or minus zero.
LLVM_ABI bool isDenormal () const
 IEEE-754R isSubnormal(): Returns true if and only if the float is a denormal.
bool isInfinity () const
 IEEE-754R isInfinite(): Returns true if and only if the float is infinity.
bool isNaN () const
 Returns true if and only if the float is a quiet or signaling NaN.
LLVM_ABI bool isSignaling () const
 Returns true if and only if the float is a signaling NaN.
Special value setters.
LLVM_ABI void makeLargest (bool Neg=false)
 Make this number the largest magnitude normal number in the given semantics.
LLVM_ABI void makeSmallest (bool Neg=false)
 Make this number the smallest magnitude denormal number in the given semantics.
LLVM_ABI void makeNaN (bool SNaN=false, bool Neg=false, const APInt *fill=nullptr)
LLVM_ABI void makeInf (bool Neg=false)
LLVM_ABI void makeZero (bool Neg=false)
LLVM_ABI void makeQuiet ()
LLVM_ABI void makeSmallestNormalized (bool Negative=false)
 Returns the smallest (by magnitude) normalized finite number in the given semantics.

Friends

class IEEEFloatUnitTestHelper
LLVM_ABI friend hash_code hash_value (const IEEEFloat &Arg)
 Overload to compute a hash code for an APFloat value.
LLVM_ABI friend int ilogb (const IEEEFloat &Arg)
LLVM_ABI friend IEEEFloat scalbn (IEEEFloat X, int Exp, roundingMode RoundingMode)
LLVM_ABI friend IEEEFloat frexp (const IEEEFloat &X, int &Exp, roundingMode RM)

Simple Queries

fltCategory getCategory () const
const fltSemanticsgetSemantics () const
bool isNonZero () const
bool isFiniteNonZero () const
bool isPosZero () const
bool isNegZero () const
LLVM_ABI bool isSmallest () const
 Returns true if and only if the number has the smallest possible non-zero magnitude in the current semantics.
LLVM_ABI bool isSmallestNormalized () const
 Returns true if this is the smallest (by magnitude) normalized finite number in the given semantics.
LLVM_ABI bool isLargest () const
 Returns true if and only if the number has the largest possible finite magnitude in the current semantics.
LLVM_ABI bool isInteger () const
 Returns true if and only if the number is an exact integer.

Detailed Description

Definition at line 445 of file APFloat.h.

Constructor & Destructor Documentation

◆ IEEEFloat() [1/8]

◆ IEEEFloat() [2/8]

llvm::detail::IEEEFloat::IEEEFloat ( const fltSemantics & ourSemantics,
integerPart value )

◆ IEEEFloat() [3/8]

llvm::detail::IEEEFloat::IEEEFloat ( const fltSemantics & ourSemantics,
uninitializedTag tag )

Definition at line 1214 of file APFloat.cpp.

References IEEEFloat().

◆ IEEEFloat() [4/8]

llvm::detail::IEEEFloat::IEEEFloat ( const fltSemantics & Sem,
const APInt & API )

Definition at line 4177 of file APFloat.cpp.

References IEEEFloat().

◆ IEEEFloat() [5/8]

llvm::detail::IEEEFloat::IEEEFloat ( double d)
explicit

Definition at line 4185 of file APFloat.cpp.

References llvm::APInt::doubleToBits(), and IEEEFloat().

◆ IEEEFloat() [6/8]

llvm::detail::IEEEFloat::IEEEFloat ( float f)
explicit

Definition at line 4181 of file APFloat.cpp.

References llvm::APInt::floatToBits(), and IEEEFloat().

◆ IEEEFloat() [7/8]

llvm::detail::IEEEFloat::IEEEFloat ( const IEEEFloat & rhs)

Definition at line 1217 of file APFloat.cpp.

References IEEEFloat().

◆ IEEEFloat() [8/8]

llvm::detail::IEEEFloat::IEEEFloat ( IEEEFloat && rhs)

Definition at line 1222 of file APFloat.cpp.

References IEEEFloat().

◆ ~IEEEFloat()

llvm::detail::IEEEFloat::~IEEEFloat ( )

Definition at line 1226 of file APFloat.cpp.

Member Function Documentation

◆ add()

APFloat::opStatus llvm::detail::IEEEFloat::add ( const IEEEFloat & rhs,
roundingMode rounding_mode )

Definition at line 2156 of file APFloat.cpp.

References IEEEFloat().

Referenced by remainder(), and roundToIntegral().

◆ bitcastToAPInt()

APInt llvm::detail::IEEEFloat::bitcastToAPInt ( ) const

Definition at line 3739 of file APFloat.cpp.

References assert().

Referenced by convertToDouble(), and convertToFloat().

◆ bitwiseIsEqual()

bool llvm::detail::IEEEFloat::bitwiseIsEqual ( const IEEEFloat & rhs) const

Bitwise comparison for equality (QNaNs compare equal, 0!=-0).

Definition at line 1174 of file APFloat.cpp.

References llvm::detail::fcInfinity, llvm::detail::fcZero, IEEEFloat(), and isFiniteNonZero().

◆ changeSign()

void llvm::detail::IEEEFloat::changeSign ( )

Definition at line 2112 of file APFloat.cpp.

References isNaN(), isZero(), and llvm::NegativeZero.

Referenced by next(), and roundToIntegral().

◆ compare()

◆ compareAbsoluteValue()

APFloat::cmpResult llvm::detail::IEEEFloat::compareAbsoluteValue ( const IEEEFloat & rhs) const

◆ convert()

APFloat::opStatus llvm::detail::IEEEFloat::convert ( const fltSemantics & toSemantics,
roundingMode rounding_mode,
bool * losesInfo )

IEEEFloat::convert - convert a value of one floating point type to another.

The return value corresponds to the IEEE754 exceptions. *losesInfo records whether the transformation lost information, i.e. whether converting the result back to the original type will produce the original value (this is almost the same as return value==fsOK, but there are edge cases where this is not so).

Definition at line 2566 of file APFloat.cpp.

References llvm::detail::fcInfinity, llvm::detail::fcNaN, llvm::detail::fcZero, isFiniteNonZero(), isSignaling(), llvm::lfExactlyZero, makeNaN(), makeQuiet(), makeSmallestNormalized(), llvm::fltSemantics::minExponent, llvm::fltSemantics::nanEncoding, llvm::NanOnly, llvm::NegativeZero, llvm::fltSemantics::nonFiniteBehavior, llvm::detail::opInexact, llvm::detail::opInvalidOp, llvm::detail::opOK, llvm::partCountForBits(), llvm::fltSemantics::precision, llvm::shiftRight(), llvm::APInt::tcAssign(), llvm::APInt::tcSet(), llvm::APInt::tcSetBit(), and llvm::APInt::tcShiftLeft().

Referenced by remainder().

◆ convertFromAPInt()

APFloat::opStatus llvm::detail::IEEEFloat::convertFromAPInt ( const APInt & Val,
bool isSigned,
roundingMode rounding_mode )

◆ convertFromString()

Expected< APFloat::opStatus > llvm::detail::IEEEFloat::convertFromString ( StringRef str,
roundingMode rounding_mode )

◆ convertToDouble()

double llvm::detail::IEEEFloat::convertToDouble ( ) const

Definition at line 3809 of file APFloat.cpp.

References assert(), bitcastToAPInt(), and llvm::APInt::bitsToDouble().

Referenced by llvm::APFloat::convertToDouble().

◆ convertToFloat()

float llvm::detail::IEEEFloat::convertToFloat ( ) const

Definition at line 3802 of file APFloat.cpp.

References assert(), bitcastToAPInt(), and llvm::APInt::bitsToFloat().

Referenced by llvm::APFloat::convertToFloat().

◆ convertToHexString()

unsigned int llvm::detail::IEEEFloat::convertToHexString ( char * dst,
unsigned int hexDigits,
bool upperCase,
roundingMode rounding_mode ) const

Write out a hexadecimal representation of the floating point value to DST, which must be of sufficient size, in the C99 form [-]0xh.hhhhp[+-]d.

Return the number of characters written, excluding the terminating NUL.

Definition at line 3329 of file APFloat.cpp.

References llvm::detail::fcInfinity, llvm::detail::fcNaN, llvm::detail::fcNormal, llvm::detail::fcZero, llvm::infinityL, llvm::infinityU, llvm::NaNL, and llvm::NaNU.

◆ convertToInteger()

◆ divide()

APFloat::opStatus llvm::detail::IEEEFloat::divide ( const IEEEFloat & rhs,
roundingMode rounding_mode )

◆ fusedMultiplyAdd()

◆ getCategory()

fltCategory llvm::detail::IEEEFloat::getCategory ( ) const
inline

Definition at line 573 of file APFloat.h.

Referenced by isSmallestNormalized().

◆ getExactLog2Abs()

int llvm::detail::IEEEFloat::getExactLog2Abs ( ) const

◆ getSemantics()

const fltSemantics & llvm::detail::IEEEFloat::getSemantics ( ) const
inline

Definition at line 574 of file APFloat.h.

Referenced by ilogb.

◆ isDenormal()

bool llvm::detail::IEEEFloat::isDenormal ( ) const

IEEE-754R isSubnormal(): Returns true if and only if the float is a denormal.

Definition at line 1033 of file APFloat.cpp.

References isFiniteNonZero(), and llvm::APInt::tcExtractBit().

Referenced by ilogb, isNormal(), and next().

◆ isFinite()

bool llvm::detail::IEEEFloat::isFinite ( ) const
inline

Returns true if and only if the current value is zero, subnormal, or normal.

This means that the value is not infinite or NaN.

Definition at line 550 of file APFloat.h.

References isInfinity(), and isNaN().

Referenced by fusedMultiplyAdd(), isFiniteNonZero(), and isInteger().

◆ isFiniteNonZero()

bool llvm::detail::IEEEFloat::isFiniteNonZero ( ) const
inline

◆ isInfinity()

bool llvm::detail::IEEEFloat::isInfinity ( ) const
inline

IEEE-754R isInfinite(): Returns true if and only if the float is infinity.

Definition at line 560 of file APFloat.h.

References llvm::detail::fcInfinity.

Referenced by ilogb, isFinite(), and roundToIntegral().

◆ isInteger()

bool llvm::detail::IEEEFloat::isInteger ( ) const

Returns true if and only if the number is an exact integer.

Definition at line 1166 of file APFloat.cpp.

References llvm::detail::cmpEqual, compare(), IEEEFloat(), isFinite(), llvm::detail::rmTowardZero, and llvm::truncated.

◆ isLargest()

bool llvm::detail::IEEEFloat::isLargest ( ) const

Returns true if and only if the number has the largest possible finite magnitude in the current semantics.

Definition at line 1149 of file APFloat.cpp.

References llvm::AllOnes, llvm::APFloat::hasSignificand(), isFiniteNonZero(), and llvm::NanOnly.

Referenced by next().

◆ isNaN()

bool llvm::detail::IEEEFloat::isNaN ( ) const
inline

Returns true if and only if the float is a quiet or signaling NaN.

Definition at line 563 of file APFloat.h.

References llvm::detail::fcNaN.

Referenced by changeSign(), hash_value, ilogb, isFinite(), isSignaling(), makeQuiet(), and roundToIntegral().

◆ isNegative()

bool llvm::detail::IEEEFloat::isNegative ( ) const
inline

IEEE-754R isSignMinus: Returns true if and only if the current value is negative.

This applies to zeros and NaNs as well.

Definition at line 538 of file APFloat.h.

Referenced by isNegZero(), isPosZero(), next(), roundToIntegral(), and toString().

◆ isNegZero()

bool llvm::detail::IEEEFloat::isNegZero ( ) const
inline

Definition at line 578 of file APFloat.h.

References isNegative(), and isZero().

◆ isNonZero()

bool llvm::detail::IEEEFloat::isNonZero ( ) const
inline

Definition at line 575 of file APFloat.h.

◆ isNormal()

bool llvm::detail::IEEEFloat::isNormal ( ) const
inline

IEEE-754R isNormal: Returns true if and only if the current value is normal.

This implies that the current value of the float is not zero, subnormal, infinite, or NaN following the definition of normality from IEEE-754R.

Definition at line 544 of file APFloat.h.

References isDenormal(), and isFiniteNonZero().

◆ isPosZero()

bool llvm::detail::IEEEFloat::isPosZero ( ) const
inline

Definition at line 577 of file APFloat.h.

References isNegative(), and isZero().

◆ isSignaling()

bool llvm::detail::IEEEFloat::isSignaling ( ) const

Returns true if and only if the float is a signaling NaN.

Definition at line 4539 of file APFloat.cpp.

References llvm::FiniteOnly, isNaN(), isSignaling(), llvm::NanOnly, and llvm::APInt::tcExtractBit().

Referenced by convert(), isSignaling(), next(), and roundToIntegral().

◆ isSmallest()

bool llvm::detail::IEEEFloat::isSmallest ( ) const

Returns true if and only if the number has the smallest possible non-zero magnitude in the current semantics.

Definition at line 1039 of file APFloat.cpp.

References isFiniteNonZero().

Referenced by next().

◆ isSmallestNormalized()

bool llvm::detail::IEEEFloat::isSmallestNormalized ( ) const

Returns true if this is the smallest (by magnitude) normalized finite number in the given semantics.

Definition at line 1047 of file APFloat.cpp.

References llvm::detail::fcNormal, and getCategory().

◆ isZero()

bool llvm::detail::IEEEFloat::isZero ( ) const
inline

Returns true if and only if the float is plus or minus zero.

Definition at line 553 of file APFloat.h.

Referenced by changeSign(), divide(), ilogb, isFiniteNonZero(), isNegZero(), isPosZero(), mod(), multiply(), remainder(), and roundToIntegral().

◆ makeInf()

void llvm::detail::IEEEFloat::makeInf ( bool Neg = false)

◆ makeLargest()

void llvm::detail::IEEEFloat::makeLargest ( bool Neg = false)

Make this number the largest magnitude normal number in the given semantics.

Definition at line 4115 of file APFloat.cpp.

References llvm::AllOnes, llvm::detail::fcNormal, llvm::detail::integerPartWidth, llvm_unreachable, makeLargest(), and llvm::NanOnly.

Referenced by makeLargest(), and next().

◆ makeNaN()

◆ makeQuiet()

void llvm::detail::IEEEFloat::makeQuiet ( )

Definition at line 4729 of file APFloat.cpp.

References assert(), isNaN(), makeQuiet(), llvm::NanOnly, and llvm::APInt::tcSetBit().

Referenced by convert(), makeQuiet(), and roundToIntegral().

◆ makeSmallest()

void llvm::detail::IEEEFloat::makeSmallest ( bool Neg = false)

Make this number the smallest magnitude denormal number in the given semantics.

Definition at line 4147 of file APFloat.cpp.

References llvm::detail::fcNormal, llvm_unreachable, makeSmallest(), and llvm::APInt::tcSet().

Referenced by makeSmallest(), and next().

◆ makeSmallestNormalized()

void llvm::detail::IEEEFloat::makeSmallestNormalized ( bool Negative = false)

Returns the smallest (by magnitude) normalized finite number in the given semantics.

Parameters
Negative- True iff the number should be negative

Definition at line 4161 of file APFloat.cpp.

References llvm::detail::fcNormal, llvm_unreachable, makeSmallestNormalized(), and llvm::APInt::tcSetBit().

Referenced by convert(), IEEEFloat(), makeSmallestNormalized(), and next().

◆ makeZero()

void llvm::detail::IEEEFloat::makeZero ( bool Neg = false)

◆ mod()

◆ multiply()

APFloat::opStatus llvm::detail::IEEEFloat::multiply ( const IEEEFloat & rhs,
roundingMode rounding_mode )

◆ needsCleanup()

bool llvm::detail::IEEEFloat::needsCleanup ( ) const
inline

Returns whether this instance allocated memory.

Definition at line 463 of file APFloat.h.

◆ next()

APFloat::opStatus llvm::detail::IEEEFloat::next ( bool nextDown)

IEEE-754R 5.3.1: nextUp/nextDown.

IEEE-754R 2008 5.3.1: nextUp/nextDown.

NOTE since nextDown(x) = -nextUp(-x), we only implement nextUp with appropriate sign switching before/after the computation.

Definition at line 4555 of file APFloat.cpp.

References assert(), changeSign(), llvm::detail::fcInfinity, llvm::detail::fcNaN, llvm::detail::fcNormal, llvm::detail::fcZero, llvm::FiniteOnly, llvm::APFloat::hasSignificand(), isDenormal(), isLargest(), isNegative(), isSignaling(), isSmallest(), makeLargest(), makeNaN(), makeSmallest(), makeSmallestNormalized(), llvm::NanOnly, llvm::NegativeZero, next(), llvm::detail::opInvalidOp, llvm::detail::opOK, llvm::APInt::tcDecrement(), llvm::APInt::tcSet(), and llvm::APInt::tcSetBit().

Referenced by next().

◆ operator=() [1/2]

IEEEFloat & llvm::detail::IEEEFloat::operator= ( const IEEEFloat & rhs)

Definition at line 1008 of file APFloat.cpp.

References IEEEFloat().

◆ operator=() [2/2]

IEEEFloat & llvm::detail::IEEEFloat::operator= ( IEEEFloat && rhs)

Definition at line 1020 of file APFloat.cpp.

References IEEEFloat().

◆ operator==()

bool llvm::detail::IEEEFloat::operator== ( const IEEEFloat & ) const
delete

The definition of equality is not straightforward for floating point, so we won't use operator==.

Use one of the following, or write whatever it is you really mean.

References IEEEFloat(), and LLVM_ABI.

◆ remainder()

◆ roundToIntegral()

◆ subtract()

APFloat::opStatus llvm::detail::IEEEFloat::subtract ( const IEEEFloat & rhs,
roundingMode rounding_mode )

Definition at line 2162 of file APFloat.cpp.

References IEEEFloat().

Referenced by mod(), remainder(), and roundToIntegral().

◆ toString()

void llvm::detail::IEEEFloat::toString ( SmallVectorImpl< char > & Str,
unsigned FormatPrecision = 0,
unsigned FormatMaxPadding = 3,
bool TruncateZero = true ) const

Converts this value into a decimal string.

Parameters
FormatPrecisionThe maximum number of digits of precision to output. If there are fewer digits available, zero padding will not be used unless the value is integral and small enough to be expressed in FormatPrecision digits. 0 means to use the natural precision of the number.
FormatMaxPaddingThe maximum number of zeros to consider inserting before falling back to scientific notation. 0 means to always use scientific notation.
TruncateZeroIndicate whether to remove the trailing zero in fraction part or not. Also setting this parameter to false forcing producing of output more similar to default printf behavior. Specifically the lower e is used as exponent delimiter and exponent always contains no less than two digits.

Number Precision MaxPadding Result


1.01E+4 5 2 10100 1.01E+4 4 2 1.01E+4 1.01E+4 5 1 1.01E+4 1.01E-2 5 2 0.0101 1.01E-2 4 2 0.0101 1.01E-2 4 1 1.01E-2

Definition at line 4466 of file APFloat.cpp.

References llvm::detail::fcInfinity, llvm::detail::fcNaN, llvm::detail::fcNormal, llvm::detail::fcZero, isNegative(), llvm::partCountForBits(), and toString().

Referenced by toString().

◆ frexp

◆ hash_value

LLVM_ABI friend hash_code hash_value ( const IEEEFloat & Arg)
friend

Overload to compute a hash code for an APFloat value.

Note that the use of hash codes for floating point values is in general frought with peril. Equality is hard to define for these values. For example, should negative and positive zero hash to different codes? Are they equal or not? This hash value implementation specifically emphasizes producing different codes for different inputs in order to be used in canonicalization and memoization. As such, equality is bitwiseIsEqual, and 0 != -0.

Definition at line 3477 of file APFloat.cpp.

References llvm::hash_combine(), llvm::hash_combine_range(), IEEEFloat(), isFiniteNonZero(), isNaN(), and llvm::fltSemantics::precision.

◆ IEEEFloatUnitTestHelper

friend class IEEEFloatUnitTestHelper
friend

Definition at line 816 of file APFloat.h.

References IEEEFloatUnitTestHelper.

Referenced by IEEEFloatUnitTestHelper.

◆ ilogb

◆ scalbn

LLVM_ABI friend IEEEFloat scalbn ( IEEEFloat X,
int Exp,
roundingMode RoundingMode )
friend

Definition at line 4753 of file APFloat.cpp.

References IEEEFloat(), llvm::lfExactlyZero, and X.

Referenced by mod().


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