JavaScript equation solver library
Asked Answered
S

5

23

Is there a JavaScript library or function that will solve equations for variables?

Such as 9 = 3 + x and solve for x. But it should also solve more advanced equations that include sine, cosine, and tangent.

Scallop answered 22/12, 2010 at 22:29 Comment(4)
if you make a "constraint network" it will be possable.Shields
Long shot, but maybe you can create a JS library to interact with the Wolfram Alpha API.Contraoctave
Note that in the JavaScript number format 0.1 + 0.2 is not equal to 0.3. That makes solving equations that contain decimal values a pain.Carreno
@ŠimeVidas - Floating points... :(Whipstitch
N
13

You can approximate the solution by doing what excel calls "Goal Seek" - testing values for x until both sides of the equation approximately match. You can do this by splitting the equation by the "=" sign, replacing each occurence of x with a value, evaling both sides, and determining if the difference falls below a certain threshold. While relatively simple, there are flaws to this method though (other than the fact that it is an approximation), for example the algorithm may think the two sides are converging when in fact it is just a local min/max and will diverge after the difference falls just below your threshold. You'll also need to test multiple start points to solve equations with more than one solution.

For a program to actually solve an equation as a human would (by rearranging the two sides of the equation and applying inverse functions, derivatives/integrals and whatnot) is far more complex, and somehow feels entirely proprietary ;)

Naominaor answered 22/12, 2010 at 23:47 Comment(0)
S
20

I'd like to propose nerdamer. It can algebraically solve up to quartic functions and it can numerically solve a range of functions. Another library to consider is Algebrite.

//solve linear equations
var x = nerdamer.solve('(x+1)*3=x-6', 'x');
console.log(x.toString());
//quadratic
var x2 = nerdamer.solve('x^2-8x+15', 'x');
console.log(x2.toString());
//quadratic algebraically
var x3 = nerdamer.solve('x^2-ax+3*b', 'x');
console.log(x3.toString());
//multiple roots
var x4 = nerdamer.solve('x^6+41*x^5+652*x^4+5102*x^3+20581*x^2+40361*x+30030', 'x');
console.log(x4.toString());
//functions - numerically around to zero up to a predefined range
var x5 = nerdamer.solve('cos(x)^2+sin(x-1)', 'x');
console.log(x5.toString());
//solve a system of linear equations
var x6 = nerdamer.solveEquations(['2x+y=7', 'x-y+3z=11', 'y-z=-1']);
console.log(x6.toString());
//solve a system of nonlinear equations
var x7 = nerdamer.solveEquations(['3*x^2/y=2', 'z*x*y-1=35', '5*z^2+7=52']);
console.log(x7.toString());
<script src="https://cdn.jsdelivr.net/npm/nerdamer@latest/nerdamer.core.js"></script>
<script src="https://cdn.jsdelivr.net/npm/nerdamer@latest/Algebra.js"></script>
<script src="https://cdn.jsdelivr.net/npm/nerdamer@latest/Calculus.js"></script>
<script src="https://cdn.jsdelivr.net/npm/nerdamer@latest/Solve.js"></script>
Subcontract answered 25/7, 2018 at 21:53 Comment(0)
N
13

You can approximate the solution by doing what excel calls "Goal Seek" - testing values for x until both sides of the equation approximately match. You can do this by splitting the equation by the "=" sign, replacing each occurence of x with a value, evaling both sides, and determining if the difference falls below a certain threshold. While relatively simple, there are flaws to this method though (other than the fact that it is an approximation), for example the algorithm may think the two sides are converging when in fact it is just a local min/max and will diverge after the difference falls just below your threshold. You'll also need to test multiple start points to solve equations with more than one solution.

For a program to actually solve an equation as a human would (by rearranging the two sides of the equation and applying inverse functions, derivatives/integrals and whatnot) is far more complex, and somehow feels entirely proprietary ;)

Naominaor answered 22/12, 2010 at 23:47 Comment(0)
F
5

A quick search turns up algebra.js and js-solver. I don't know anything about them, but they seem legit. algebra.js has a nice OOP API, but doesn't appear to handle trigonometric functions.

Fullfledged answered 4/10, 2015 at 12:41 Comment(0)
U
2

Look at the script at Newton's Method Program for f(x)=0. It solves the equation using Newton's tangent method.

Unfeigned answered 23/12, 2010 at 10:40 Comment(0)
F
1

Ceres.js can find the solution to an array of equations of the form f(x) = 0. It is ported from C++ to JavaScript with Emscripten. The file is a bit large but if you need a really high performance solver this is your best bet. It runs in web-assembly so the speed is high. Here is an example:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
</head>
<body>

<h3>Powell Function</h3>
    <p>This is an example of the solution of the powell function using Ceres.js</p>
    <pre><code id="powell_demo_code" class="language-js"></code></pre>
    <textarea id="powell_demo" rows="40" cols="110"></textarea>
    <script id="powell_demo_code_source">
        async function ceresSolvePowell() {
            const {Ceres} = await import('https://cdn.jsdelivr.net/gh/Pterodactylus/Ceres.js@latest/dist/ceres.min.js');
    
            var fn1 = function f1(x){
                return (x[0]+10*x[1]);
            }
    
            var fn2 = function f2(x){
                return (Math.sqrt(5)*(x[2]-x[3]));
            }
            
            var fn3 = function f3(x){
                return Math.pow(x[1]-2*x[2],2);
            }
            
            var fn4 = function f4(x){
                return Math.sqrt(10)*Math.pow(x[0]-x[3],2);
            }
            
            let solver = new Ceres()
            solver.addFunction(fn1) //Add the first equation to the solver.
            solver.addFunction(fn2) //Add the second equation to the solver.
            solver.addFunction(fn3) //Add the third equation to the solver.
            solver.addFunction(fn4) //Add the forth equation to the solver.
            //solver.addCallback(c1) //Add the callback to the solver.
            //solver.addLowerbound(0,1.6) //Add a lower bound to the x[0] variable
            //solver.addUpperbound(1,1.7) //Add a upper bound to the x[1] variable
            
            var x_guess = [1,2,3,4] //Guess the initial values of the solution.
            let s = await solver.solve(x_guess) //Solve the equation
            var x = s.x //assign the calculated solution array to the variable x
            document.getElementById("powell_demo").value = s.report //Print solver report
            solver.remove() //required to free the memory in C++
            
        }
        ceresSolvePowell();
    </script>
</body>
</html>
Forerun answered 9/4, 2020 at 3:6 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.