A Graphically Enhanced Method for Computing Real Roots of Nonlinear Functions
A Graphically Enhanced Method for Computing Real Roots of Nonlinear Functions
Mathematica's built-in function FindRoot is the preferred method for finding a zero of a nonlinear function . However, determining all the zeros of in a specified interval using FindRoot can be challenging, as this requires having good initial guesses for all the roots. In some cases, the initial guesses can be found by examining the asymptotic structure of as , but this is not always possible.
f(x)
f(x)
f(x)
x∞
This Demonstration shows how the computation of the zeros for a nonlinear equation can readily be accomplished by augmenting the calculation with a graphical technique to obtain the initial guesses in a specified interval ≤x≤. The functions considered in this Demonstration are (x) (the Bessel function of the first kind) or a linear combinations of Bessel functions such as [(x)-(x)] or (x)(2x)-(x)(2x). Another possible problem involves , in a numerical solution of the Lorenz equation. The general idea of calculating approximate roots of a function using graphical techniques is discussed in [1].
f(x)=0
x
0
x
1
J
n
1
2
J
n-1
J
n+1
Y
n
J
n
J
n
Y
n
L(x)
f(x)
You can specify the order of the Bessel functions using a slider. For the Lorenz function, you can specify the parameters in the Lorenz equations. For certain values of the Lorenz parameters, the solution is chaotic, and thus the zeros of are not predictable. The interval for the roots can be specified using the sliders for and , where =+Δx. Clicking the "function plot" button shows a plot of the selected function with the calculated roots superimposed on the plot as magenta dots. You can view the numerical values of the zeros by clicking the "first few roots" button.
n
σ,r,b
L(x)
x
0
Δx
x
1
x
0