float InvSqrt(float x)
{
float xhalf = 0.5f*x;
int i = *(int*)&x; // get bits for floating value
i = 0x5f3759df - (i>>1); // gives initial guess y0
x = *(float*)&i; // convert bits back to float
x = x*(1.5f-xhalf*x*x); // Newton step, repeating increases accuracy
return x;
}
这个是求1/sqrt(x)的函数。
double CustomSquare(double number)
{
int i;
if (number == 0.0)
return 0.0;
double result = number / 2.0; //迭代初始数
for (i = 1; i <= ITERATIONTIMES; i++)
{
result = 0.5 * (result + number / result);
}
return result;
}