Matlab 数值计算----牛顿迭代法

 Newton.m函数

function [x_star,index,it] = Newton(fun,x,ep,it_max)
%求解非线性方程的牛顿法
%第一个分量是函数值,第二个分量是导数值
% x为初始点
% ep为精度,当 | x(k)-x(k-1) |=it_max)
% it为迭代次数
if nargin<4 it_max=100;end                               
if nargin<3 ep=1e-5;end
index=0;k=1;
while k

NewTest.m函数

fun=inline('[x^3-x-1,3*x^2-1]');
[x_star,index,it] = Newton(fun,1.5)

结果:

>> NewTest


x_star =


    1.3247




index =


     1




it =


     4


>> 

你可能感兴趣的:(Matlab 数值计算----牛顿迭代法)