Fixed point iteration to find the roots of 0=x-tan(x)

Click For Summary
The discussion focuses on using fixed point iteration to find the roots of the equation 0 = x - tan(x). The user initially rearranged the equation to x = arctan(x) for convergence but struggled with the implementation in MATLAB, particularly with the iteration logic and understanding how to find multiple roots. It was clarified that the roots of x = tan(x) are not periodic like tan(x) itself, and the user was advised to use the relationship x = nπ + θ to find roots within specific intervals. The conversation emphasized the need for careful selection of initial guesses and the importance of using the arctan function for convergence, as the derivative of tan(x) does not guarantee stability in fixed point iterations. Ultimately, the user was guided to refine their approach to effectively locate the positive roots of the equation.
  • #31
Still off course. So let's get back on course. You are trying to find solutions to

x=\tan x

using a fixed point iteration approach. That technique won't work with the above because tan'(x)>=1. Taking the inverse tangent function of both sides doesn't quite work, either, because atan(tan(x)) is only equal to x if x lies in the principal domain of atan.

You have already written x as x=n\pi + \theta. Substituting this on both sides of the above equation yields

n\pi + \theta=\tan(n\pi + \theta) = \tan\theta

By design, \theta\,\in\,(0,\pi/2)\,\forall n>0 In other words, theta is in the principal domain of atan, so you now can take the inverse tangent of both sides of the above. Do that.
 
Physics news on Phys.org
  • #32
Alright, so
atan(n\pi + \theta)= (n\pi +\theta) = \theta
So theta is periodic like the sin or cos functions?
 
  • #33
No. Theta is just a variable here.

You do not know that \arctan(\tan(n\pi+\theta))=n\pi+\theta. In fact, this is not true. The domain of arctan is -pi/2 to pi/2 (at least as implemented in most programming languages). However, you do know that \tan(n\pi+\theta)=\tan\theta due to trig identities.
 
  • #34
Ok. Does arctan (tan (\theta))=\theta?
If it does, then arctan (n*pi + \theta)=(\theta). I think I'm going in circles.
 
  • #35
Brendy said:
Ok. Does arctan (tan (\theta))=\theta?
It does if theta is in the principal domain of arctan. That was the point of creating that variable: to ensure that it does lie in the principal domain of arctan.

If it does, then arctan (n*pi + \theta)=(\theta). I think I'm going in circles.
Yes, you are. So, one step at a time.
  1. You want to find the positive solutions to x=\tan x.
  2. This is in the right form for fixed point iteration, but a fixed point iteration using the above will not converge.
  3. Taking the inverse tangent of both sides doesn't help immediately because all solutions but the trivial solution lie outside the principal domain of arctan.
  4. So, introduce a new variable that will be in the principal domain: x\equiv n\pi+\theta.
  5. Now the problem becomes one of solving n\pi+\theta = \tan(n\pi+\theta).
  6. The right hand side of the above, \tan(n\pi+\theta), reduces to \tan\theta via the trig identity \tan(a+b) = (\tan a + \tan b)/(1-\tan a \tan b).
  7. Now the problem becomes one of solving n\pi+\theta = \tan\theta.
  8. And now you can safely apply the arc tangent function to both sides because, by design, theta is in the principal domain of arctan.

Try to take it from here.
 
Last edited:
  • #36
Isn't that what I wrote above? arctan (n\pi+\theta) = \theta\<br />
 
  • #37
Fine. Can you take it forward from post#35?
 
  • #38
I thought that was taking it forward? I'm sorry, I really don't know what I'm after in this question.
My first instinct is to get everything in terms of x which would mean that arctan(x) = theta but I see that I did that a few posts ago but that was going off course and it doesn't really get me anywhere.
 
  • #39
You seem to have lost sight of the goal of this problem, which is to find an equation of the form x=f(x) than can be used in a fixed point iteration scheme. You need f(x) to involve arctan, not tangent.

This isn't that hard. Look at step 7 in post number 35.
 
  • #40
Right.
arctan (x) = x - n\pi\
so,
x = arctan (x) + n\pi\

This actually looks correct for once.
 
  • #41
That's not right. Forget about x! You need to solve for theta.
 
  • #42
arctan <br /> (n\pi+\theta) = \theta\<br /> <br />
That's as far as I can get in solving it. I'm not sure how to proceed from there.
 
  • #43
You're there. If you don't see it, just exchange the left and right hand sides. (use the fact that if a=b then b=a).
 
  • #44
<br /> \theta\ = arctan (n\pi+\theta) <br /> <br />
So that's it? Do I try and get everything in terms of x now or is this what the algorithm will use?
 
  • #45
That's it. You will solve for x at the very end.
 
  • #46
Do you mean at the end of running the algorithm? Also, when I solve for x, the x represents the roots, right? Not just another initial guess? Or do I use what I find x to be as the next initial guess?
 
  • #47
You use a different value for n to find the next root. It doesn't really matter what you use for an initial guess, so long as it is somewhere between 0 and pi/2, exclusive of the end points.

That said, it's not too hard to form a very good guess. The solution for theta will be close to pi/2 (very close for large n). Writing the solution for some particular n as \theta_n,

\theta_n = \frac{\pi}2 - \epsilon_n

Thus \tan\theta_n = 1/\tan\epsilon_n \approx 1/\epsilon_n if \epsilon_n is small (which it will be).

See if you can take it from here. Or just use some value between 0 and pi/2 as your initial guess.
 
  • #48
Thanks alot, you've been a massive help.
One last thing, what are f_old and f_new doing in my code? After I edit the line x_new... to the expression for theta, it will converge on a root but I'm not sure what those two lines after that mean. Are they needed?
Also, is it supposed to converge so quickly? At the moment, it converges on the first root within 5 iterations with 1 as an initial guess.
 
Last edited:
  • #49
You wrote that code; you are the one who should know what it is doing. You will of course have to rewrite your code to use this new formula.

Last thing: I wouldn't bother with the trivial solution. You know that solution, and a fixed point iteration scheme isn't really valid for finding the trivial solution because it sits right at a point where tan'(x)=atan'(x)=1. The derivative has to be strictly less than one for a fixed point iteration to converge.
 
  • #50
I didn't write the code. I modified an existing program that was solving x_n+1 = e^-x_n
Which solution are you referring to? Even changing the initial guess to something further away from the root such as 0.5 sees it converging within 6 iterations.
 
  • #51
That algorithm doesn't converge. I just took your code from post #17; it stopped after 50 iterations because it failed to converge.

Look at it this way: \tan x \approx x(1 - x^2/3) for small x. All setting x=\arctan(x) does when x gets even close to zero is to scale x by a factor that is nearly equal to 1.
 
  • #52
After rewriting it so that x_new... line is now x_new= atan (pi + x_old) it converged within 6 iterations. So is that just a fluke then? It is giving me the correct number to find the roots though.
I don't follow post #51 at all I'm sorry.
 

Similar threads

  • · Replies 16 ·
Replies
16
Views
1K
  • · Replies 2 ·
Replies
2
Views
11K
  • · Replies 22 ·
Replies
22
Views
2K
Replies
2
Views
1K
  • · Replies 2 ·
Replies
2
Views
2K
  • · Replies 2 ·
Replies
2
Views
2K
  • · Replies 17 ·
Replies
17
Views
3K
  • · Replies 1 ·
Replies
1
Views
20K
  • · Replies 3 ·
Replies
3
Views
4K
  • · Replies 12 ·
Replies
12
Views
2K