Skip to content

Instantly share code, notes, and snippets.

@casoetan
Forked from joelpt/squirt.js
Created August 28, 2018 17:49
Show Gist options
  • Save casoetan/daea4c4efc12f3f96adaae94bf223269 to your computer and use it in GitHub Desktop.
Save casoetan/daea4c4efc12f3f96adaae94bf223269 to your computer and use it in GitHub Desktop.
Manually calculate the square root of a number with Javascript
// The Babylonian Method
// http://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method
// @param n - the number to compute the square root of
// @param g - the best guess so far (can omit from initial call)
function squirt(n, g) {
if (!g) {
// Take an initial guess at the square root
g = n / 2.0;
}
var d = n / g; // Divide our guess into the number
var ng = (d + g) / 2.0; // Use average of g and d as our new guess
if (g == ng) {
// The new guess is the same as the old guess; further guesses
// can get no more accurate so we return this guess
return g;
}
// Recursively solve for closer and closer approximations of the square root
return squirt(n, ng);
}
console.log(squirt(42)); // 6.48074069840786
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment