MATLAB弦截法求解非线性方程

MATLAB弦截法求解非线性方程

用Newton法解非线性方程时,当f比较复杂时就比较难以实现了,弦解法的好处可以用f(x)在两点上的值构造一次插值函数来回避微商的计算。其迭代格式:

X_{k+1}=X_{k}-\frac{f(X_{k})}{f(X_{k}-f(X_{k-1})}(X_{k}-X_{k-1})

1.弦截法的MATLAB实现

按照弦截法的原理进行程序的编写:

!!!!!!!!!!对于小白,千万别直接复制后放在matlab中运行,应该新建一个脚本,文件名建议为secant.m。

function [pl,err,k,y]=secant(f,p0,p1,delta,max1)
%f是给定的非线性函数
%p0,p1为初始值(可以理解为选取的x(k),x(k-1)两点)
%delta为给定误差界限
%max1为迭代的误差上限
%p1为所求的方程的近似解(这里是function中的pl)
%err为p1-p0的绝对值
%k为所需需要的迭代次数
%y=f(pl)
k=0,p0,p1,feval('f',p0),feval('f',p1)
for k=1:max1
    p2=p1-feval('f',p1)*(p1-p0)/(feval('f',p1)-feval('f',p0));
    err=abs(p2-p1);
    p0=p1;
    p1=p2;
    p1,err,k,y=feval('f',p1);
    if (err<delta)|(y==0),break,end
end

2.例题示例:

解线性方程组0.019x^3-0.036x^2-1.973=0

首先用一个名为f.m的文件定义函数f(x)=0.019x^3-0.036x^2-1.973

!!!!!!!!!!对于小白,千万别直接复制后放在matlab中运行,应该新建一个脚本,名为f.m

function y=f(x)
y=0.019*x^3-0.036*x^2-0.049*x-1.973

可以将y=后更改为自己的求解函数

接下来开始求解函数

在MATLAB命令窗口输入,前面两部分是脚本里面,此时脚本完成后关闭,在命令窗口!命令窗口!

开始运行并显示输出结果:

结果表明经过5次迭代得到了满足精度要求的近似解x=5.6295,且f(x)=-3.2285e-3

3.错误解决

我遇到的是问题是:

3.1方法1

确保脚本文件在工作目录:我的存放在此处

3.2方法2

确保函数名与脚本名一致:

假如不一致的情况,错误示例:

正确应该将文件名改为secant.m

3.3方法3

先运行一下脚本secant.m

如何在命令窗口再输入secant('f',5.2,5.21,10^(-6),11)

 

 

不足之处还望各位及时指正!!!!!!!!

  • 27
    点赞
  • 124
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值