blob: 8ba6f8ceed299c0e5e3c50babcd42a17a81d37f8 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/* 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)
{
float xhalf = 0.5f*x;
int i = *(int*)&x;
i = 0x5f375a86- (i>>1);
x = *(float*)&i;
x = x*(1.5f-xhalf*x*x);
return x;
}
float fastSqrt(float x)
{
return 1.0f/fastInvSqrt(x);
}
|