I need to change this code into one that can solve complex roots
    8 ビュー (過去 30 日間)
  
       古いコメントを表示
    
    Elena Cecilia Valero Garza
 2022 年 9 月 12 日
  
I have this Newton-Raphson method code, but I need to change it into a code that can actually solve polynomials and give as an answer complex roots.
Code:
function [tabla, raiz]=newtonraphsonMN(f,xa,errorD,imax)
tabla=[];
error=Inf;
i=0;
xr=NaN;
df=diff(f);
while error>errorD && i<=imax
    i=i+1;
    fxa=double(subs(f,xa));
    fpxa=double(subs(df,xa));
    xr=xa-fxa/fpxa;
    error=100*abs((xr-xa)/xr);
    tabla=[tabla; [xa fxa fpxa xr error]];
    xa=xr;
end
%raiz
raiz=xr;
0 件のコメント
採用された回答
  John D'Errico
      
      
 2022 年 9 月 12 日
        
      編集済み: John D'Errico
      
      
 2022 年 9 月 13 日
  
      Interesting. It does not work? :) Gosh, You could have fooled me. I'll try an example. (I've attached the code you gave, so it will be used.)
syms X
f = X^2 + X + 1;
Does f has complex roots?
solve(f)
vpa(ans)
Of course. I'd not have used an example that lacks complex roots, since that is your question.
[tabla, raiz]=newtonraphsonMN(f,1 + i,1e-12,100);
Strange. 
tabla
format long
raiz
To me, it seems to have worked. But then, what do I know? :)
(Hint: Do you see what I did different?)
2 件のコメント
  Torsten
      
      
 2022 年 9 月 13 日
				To solve for polynomial roots, use MATLAB's "roots" command.
Newton's method will only give you one solution per call. Which one you get depends on the initial guess.
Example:
To determine all roots of p(x) = x^2+x+1:
p = [1 1 1];
sol = roots(p)
polyval(p,sol)
その他の回答 (0 件)
参考
カテゴリ
				Help Center および File Exchange で Symbolic Math Toolbox についてさらに検索
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!




