2022-01-09 16:14:17 +01:00
|
|
|
//=============================================================================//
|
|
|
|
//
|
|
|
|
// Purpose: look for NANs, infinities, and underflows.
|
|
|
|
//
|
|
|
|
//=============================================================================//
|
|
|
|
|
|
|
|
#include "core/stdafx.h"
|
|
|
|
#include "mathlib/bits.h"
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// This follows the ANSI/IEEE 754-1985 standard
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
unsigned long& FloatBits(float& f)
|
|
|
|
{
|
|
|
|
return *reinterpret_cast<unsigned long*>(&f);
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned long const& FloatBits(float const& f)
|
|
|
|
{
|
|
|
|
return *reinterpret_cast<unsigned long const*>(&f);
|
|
|
|
}
|
|
|
|
|
|
|
|
float BitsToFloat(unsigned long i)
|
|
|
|
{
|
|
|
|
return *reinterpret_cast<float*>(&i);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsFinite(float f)
|
|
|
|
{
|
|
|
|
return ((FloatBits(f) & 0x7F800000) != 0x7F800000);
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned long FloatAbsBits(float f)
|
|
|
|
{
|
|
|
|
return FloatBits(f) & 0x7FFFFFFF;
|
|
|
|
}
|
|
|
|
|
|
|
|
float FloatMakePositive(float f)
|
|
|
|
{
|
2022-07-06 21:11:32 +02:00
|
|
|
return fabsf(f); // was since 2002: BitsToFloat( FloatBits(f) & 0x7FFFFFFF ); fixed in 2010
|
2022-01-09 16:14:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
float FloatNegate(float f)
|
|
|
|
{
|
|
|
|
return -f; //BitsToFloat( FloatBits(f) ^ 0x80000000 );
|
|
|
|
}
|