How to use Newton-Raphson for numerical solution of two variables?

6 Ansichten (letzte 30 Tage)
Jonas
Jonas am 8 Sep. 2013
Hello community,
I have a non-linear function f(x,y), which I would like to find the roots of with the Newton-Raphson method. However, I haven't yet found a simple code on the internet in case of two variables, which just lets me enter my function and get the result. If I find one, the solutions on the internet always need two equations, but I only have one?
  2 Kommentare
Matt J
Matt J am 8 Sep. 2013
Bearbeitet: Matt J am 8 Sep. 2013
Newton-Raphson only applies to N equations in N unknowns. If you have fewer equations than unknowns, there will normally be an infinite continuum of roots. For example,
f(x,y)=x+y
has roots at all x=-y.
Jonas
Jonas am 8 Sep. 2013
What if the function is complex? Can i divide it into a real and an imaginary equation - in that case I would have two equations? If, how?

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Matt J
Matt J am 8 Sep. 2013
Can i divide it into a real and an imaginary equation
You could just rewrite your function to return a 2x1 vector containing the real and imaginary part respectively.
If f() is your existing function, you could also do
f_new=[real(f(x,y)); imag(f(x,y))]
  7 Kommentare
Matt J
Matt J am 8 Sep. 2013
Bearbeitet: Matt J am 8 Sep. 2013
Sorry, I meant to say FSOLVE, not FZERO.

Melden Sie sich an, um zu kommentieren.


Jonas
Jonas am 8 Sep. 2013
I went one step back and did following: I got following equation with pt as a variable instead of pt = x + i*y.
eq = pt*(- 4157552041235969998848 + 14994143880568163532800*i) + pt^2*(29558214356309966848 - 131338673823403081728*i) + pt^3*(100369407825487824 + 178402860122995232*i) + pt^4*(- 3688268389229367/16 + (578208319202799*i)/16) + pt^5*(3404177150896959/32768 - (8024424565434255*i)/65536) + pt^6*(- 3003839359850141/268435456 + (2314057354380575*i)/33554432) + pt^7*(- 4711673569865107/549755813888 - (7173966121489549*i)/549755813888) + pt^8 - 200770287297318937952256 + 213383934120794144112640*i
Here it is possible to say e.g. solve(eq == 0) and I get some nice results. However, if I check one of the results and insert one of the results (e.g. pt = -15-7*i) the final result is not equal 0. How does that make sense?
  2 Kommentare
Matt J
Matt J am 8 Sep. 2013
Bearbeitet: Matt J am 8 Sep. 2013
Floating point errors probably. You have very large coefficients and also a rather large polynomial order. ROOTS might give you a more exact result (and is more appropriate anyway seeing as your function is a polynomial), but it's hard to say.
Jonas
Jonas am 8 Sep. 2013
Alright - and thank you very much for all your help!

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Systems of Nonlinear Equations finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by