blob: 78768149a7164e8d52370e63e64c54a58bd81c0b (
plain) (
tree)
|
|
/* A very fast function to calculate the approximate inverse square root of a
* floating point value and a helper function that uses it for getting the
* normal squareroot. For an explanation of the inverse squareroot function
* read:
* http://www.math.purdue.edu/~clomont/Math/Papers/2003/InvSqrt.pdf
*
* Unfortunately the original creator of this function seems to be unknown.
*/
float fastInvSqrt(float x)
{
union { int i; float x; } tmp;
float xhalf = 0.5f * x;
tmp.x = x;
tmp.i = 0x5f375a86 - (tmp.i >> 1);
x = tmp.x;
x = x * (1.5f - xhalf * x * x);
return x;
}
float fastSqrt(float x)
{
return 1.0f / fastInvSqrt(x);
}
|