Finding the multiple zeros within a prescribed interval
Show older comments
I wish to solve the nonlinar function:
=0within a prescribed interval, say (0,100] say, I'm aware of using an annonymous function and using fzero or fsolve, but how do I get say multiple solutions?
Answers (1)
deltax = 1e-4;
xright = 100;
n = floor(xright/pi);
fun = @(x)tan(x)-x;
for i=1:n
left = (2*i-1)*pi/2.0 + deltax;
right = (2*i+1)*pi/2.0 - deltax;
sol(i) = fzero(fun,[left right]);
end
sol
fun(sol)
7 Comments
Matthew Hunt
on 13 Nov 2018
Torsten
on 13 Nov 2018
Yes, with the knowledge that there is exactly one root in the interval ((2*k-1)*pi/2:(2*k+1)*pi/2)
Matthew Hunt
on 13 Nov 2018
No, the strategy to find all zeros of a function in a specified interval will always depend on the behaviour of the function itself. So no general guideline can be given.
Of course you can start at x0=0.01, evaluate the function at x=x0+deltax, x=x0+2*deltax and so on until you get a sign change. Then you can call "fzero" with the interval of the last two x-values as search interval, save the root you get and continue with this strategy until you reach the right endpoint of the search interval. But this will be quite time-consuming, and - depending on deltax - it is still not ensured that you really find all zeros.
Matthew Hunt
on 13 Nov 2018
No, the strategy to find all zeros of a function in a specified interval will always depend on the behaviour of the function itself. So no general guideline can be given.
Imagine, for example, that you were instead trying to find all roots of
contained in the interval [0,a]. No matter what
you choose, there would always be infinite roots in the interval.
you choose, there would always be infinite roots in the interval.
Torsten
on 14 Nov 2018
@Matthew Hunt:
You know that tan(x) -x -> -Inf for x->2*(k-1)*pi/2 from the right and tan(x) - x -> +Inf for x->2*(k+1)*pi/2 from the left. So there must be a root in the interval 2*(k-1)*pi/2 : 2*(k+1)*pi/2. Plotting the function tan(x) - x you can see that there is exactly one root in this interval. This explains my code and the fact that it captures all roots in a specified interval.
Categories
Find more on Direct Search in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!