Calculating PIE using javascript
Pi is one of the most fascinating numbers in mathematics due to its irrational and transcendental nature. The simplest calculation of 'pi' is to draw a circle and measure the ratio of the diameter and the circumference which gives us 2-5 decimal digits at best. Although, it may be enough for most practical purposes, calculating digits of pi has been seen as a challenge.
In recent years PIE has been calculated to 130 trilion digits
There are many formulas for computing the value of 'pi'. The most famous of this is 'Machin's formula'.
data:image/s3,"s3://crabby-images/66602/666025840d757e9487e93a77ea0a38e9eb1eb18c" alt="Altmel Gpu"
The steps to calculate pi can be summarised in three simple steps:
- Calculate arctan of 1/5 and 1/239
- Multiply arctan of 1/5 by 4 and subtract arctan of 1/239
- Divide the result by 4 to get pi
Using Taylor series, the formula for arctan is as follows:
data:image/s3,"s3://crabby-images/683c1/683c1b759f2d389bb09a14bec19177b7e4ce2396" alt="Altmel Gpu"
After some refactoring we get a factorial as:
data:image/s3,"s3://crabby-images/5a9f7/5a9f72b84b875ae1b9985ed6d25006b5d0e2907e" alt="Altmel Gpu"
We start with x and continue dividing by the factorial.
This can be written on javascript as:
function arctan(a) { var arctan = createArray(); var angle = divide(createArray(1), a); arctan = addition(arctan, angle); var k = 3; var sign = 0; while (!isEmpty(angle)) { angle = divide(angle, a * a); div = divide(angle, k); arctan = sign ? addition(arctan, div) : subtract(arctan, div); k += 2; sign = 1 - sign; } }
Once we have the arctan value, rest is just simple arithmetic.
This code is based on Ken ward's work and also of Pascal Sebah