Fast Inverse Square Root

by atalaykutlay

The legendary fast inverse square root implementation from Quake III Arena source code with the original comment text.

Fast Inverse Square Root
1float Q_rsqrt( float number )
2{
3	long i;
4	float x2, y;
5	const float threehalfs = 1.5F;
6
7	x2 = number * 0.5F;
8	y  = number;
9	i  = * ( long * ) &y;                       // evil floating point bit level hacking
10	i  = 0x5f3759df - ( i >> 1 );               // what the fuck? 
11	y  = * ( float * ) &i;
12	y  = y * ( threehalfs - ( x2 * y * y ) );   // 1st iteration
13//	y  = y * ( threehalfs - ( x2 * y * y ) );   // 2nd iteration, this can be removed
14
15	return y;
16}

✨ Code Explanation ✨

This code is an implementation of the inverse square root function (Q_rsqrt), which computes the reciprocal square root of a given float number. The function takes a float as an input and returns a float as output. The algorithm used in this implementation is known as the Fast Inverse Square Root algorithm, which was originally developed for the Quake III Arena game in 1999. It uses a clever bit manipulation trick to compute an approximation of the reciprocal square root in a very efficient way. The algorithm starts by taking the input number and dividing it by 2 to get x2. It then stores the original number in y and performs some bit-level hacking to convert the float representation of y into an integer. This is done to extract some of the bits from the floating-point representation of y, which will be used later in the algorithm. Next, the algorithm subtracts the integer representation of y shifted right by one from a magic number (0x5f3759df). This step is where the "what the fuck?" comment comes in, as it seems like a mysterious constant. However, this magic number was carefully chosen to improve the accuracy of the approximation. After this step, the algorithm converts the modified integer back into a float representation of y. It then performs a single iteration of Newton's method using the formula y = y * (threehalfs - x2 * y * y). This formula is derived from the Taylor series expansion of the reciprocal square root function. Finally, the function returns the computed value of y, which is an approximation of the reciprocal square root of the input number. The comment indicates that a second iteration can be performed, but it's not necessary for most use cases.

Share

Share
Video
A cool 10 sec video.
Share
Detailed
Title, description, and syntax highlighted code.
Share
Simple
Syntax highlighted code with gradient background colored presentation.

Comments

It looks like there is no comment for this snippet. Leave the first one!
You need to login to send a comment.

Similar Snippets

Q_rsqrt
Q_rsqrt

The legendary fast inverse square root implementation from Quake III Arena source code with the original comment text.

Language: cpp19 months ago
Count Ways To Build Good Strings
Count Ways To Build Good Strings

Solution to Leetcode problem Count Ways To Build Good Strings in C++

Language: cpp18 months ago