用区间2分法求方程的根.doc

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用区间2分法求方程的根

用区间二分法求方程的根 一、 前言 1.了解区间二分法求解方程基本方法。 2.学习掌握区间二分法求解方程根的过程。 3.学习掌握MATLAB软件有关的命令。 二、 参数说明 function root=HalfInterval(f,a,b,eps) 方程表达式:f 区间左端点:a 区间右端点:b 根的精度:eps 求得的根:root 算法设计和运行结果 1.算法设计  = 1 \* GB3 ①计算函数f(x)在区间[a,b]中点的函数值f((a+b)/2),并做下面的判断: 如果f(a)f((a+b)/2)0,转到 = 2 \* GB3 ②; 如果f(a)f((a+b)/2)0,令a=(a+b)/2,转到 = 1 \* GB3 ①; 如果f(a)f((a+b)/2)=0,则x=(a+b)/2为一个根。  = 2 \* GB3 ②如果|a-(a+b)/2|p(预先给定的精度),则x=(b+3a)/4为一个根,否则令b=(a+b)/2,转到 = 1 \* GB3 ①。 2.运行结果 r=HalfInterval(x^3-x-1,1,1.5) r = 1.3247 四、 源程序及流程图 源程序: function root=HalfInterval(f,a,b,eps) %方程表达式:f %区间左端点:a %区间右端点:b %根的精度:eps %求得的根:root if (nargin==3) eps=1.0e-4; end f1=subs(sym(f),findsym(sym(f)),a); %两端点的函数值 f2=subs(sym(f),findsym(sym(f)),b); if (f1==0) root=a; end if (f2==0) root=b; end if (f1*f20) disp(两端点函数值乘积大于0!); return; else root=FindRoots(f,a,b,eps); %调用求解子程序 end function r=FindRoots(f,a,b,eps) f_1=subs(sym(f),findsym(sym(f)),a); f_2=subs(sym(f),findsym(sym(f)),b); mf=subs(sym(f),findsym(sym(f)),(a+b)/2); %中点函数值 if (f_1*mf0) t=(a+b)/2; r=FindRoots(f,t,b,eps); %右递归 else if (f_1*mf==0) r=(a+b)/2; else if (abs(b-a)=eps) r=(b+3*a)/4; %输出根 else s=(a+b)/2; r=FindRoots(f,a,s,eps); %左递归 end end end 流程图: 开始 t=(a+b)/2 t=(a+t)/2 Y N f(a)f(t)0 f(a)f(t)0 N Y N x=(a+t)/2 t=(a+t)/2 |a-t| Y x=(a+t)/2 结束 五、 程序调试情况 最终得出的结果是一个有效数字为四位的实根。 六、 结论 本算法的优点:可以通过调节精确度来使最终得值更精确,是有效位数更多。 复杂度: 本算法流程明确简单,通俗易懂。 算法精度: 最终结果有四位有效数字,通过调节精确度是最终结果更精确。 误差分析:由于有效数字取位不同,导致结果有不同程度误差,但总体上进一步改进可使精确度更高。 改进方法:在程序中提高有效数字个数,结果更精确。 本算法与其他算法的比较: 七、 结束语 通过编程深知劳动果实获得的辛苦,一份付出一分收获,并且知道课本对我们实习的重要性,以后要加深自己的动手能力,敢于面对错误,争取给老师和自己一份满意的答卷。 八、参考文献 [1]龚纯,王正林.MATLAB常用算法程序集[M].电子工业出版社,2008.

文档评论(0)

ktj823 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档