非线性方程的弦割法,抛物线法.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
西京学院数学软件实验任务书 课程名称 数学软件实验 班级 数0901 学号 0912020119 姓名 王震 实验课题 非线性方程的弦割法,抛物线法 实验目的 熟悉非线性方程的弦割法,抛物线法 实验要求 运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成 实验内容 非线性方程的弦割法 非线性方程的抛物线法 成绩 教师 【实验课题】 非线性方程的弦割法,抛物线法 【实验目的】 熟悉非线性方程的弦割法,抛物线法 【实验内容】 1、弦割法 弦割法是函数逼近法的一种,基本思想是用用区间上的割线近似代替目标函数的导函数的曲线。并用割线与横轴交点的横坐标作为方程式的根的近似 由于上式存在微分,为了避免计算导数值,我们用差商来代替导数。即: 算法过程: 1、定义函数,输入控制精度和迭代初始值,并求出 2、进行循环迭代,若相邻的两个数值之差的绝对值小于所给定的,则跳出循环,输出 2、抛物线法 抛物线法是在函数的最优点附近取三个构造点,然后用这三个点构造一条抛物线,把这条抛物线的极值点作为函数的极值点的近似。每次构造一条抛物线后,抛物线的极值点就可作为一个新的构造点,新的构造点与原来的三个构造点经过某种算法,得到下一步抛物线逼近的三个构造点,这就是抛物线法的算法过程。,并计算和差分 注意,三点不能共线。 2、用牛顿插值法对三点、、进行插值得到一条抛物线,存在两个根: 其中,, 两个根中取其中靠近的那个根。 3、重复以上步骤,并控制精度。 【程序】 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% function [x1,n]=gexian() x0=input(请输入初始值x0=); x1=input(请输入初始值x1=); err=input(请输入误差极限err=); N=input(请输入最大迭代次数N=); x2=x1-fun(x1)*(x1-x0)/(fun(x1)-fun(x0)); n=0; while abs(x1-x0)err x0=x1; x1=x2; x2=x1-fun(x1)*(x1-x0)/(fun(x1)-fun(x0)); n=n+1; if nN disp(迭代次数过大!); return end end end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% function root=paowuxian() x0=input(请输入初值x0=); x1=input(请输入初值x1=); x2=input(请输入初值x2=); N=input(请输入最大迭代次数N=); f1=fun(x0); f2=fun(x1); if f1==0 root=x0; end if f2==0 root=x1; end if f1*f20 disp(两点之积大于0!); return else err=input(请输入误差极限err=); f1=fun(x0); f2=fun(x1); f3=fun(x2); d1=(f2-f1)/(x1-x0); d2=(f3-f2)/(x2-x1); d3=(d2-d1)/(x2-x0); B=d2+d3*(x2-x1); root=x2-2*f3/(B+sign(B)*sqrt(B^2-4*f3*d3)); t(1)=x0; t(2)=x1; t(3)=x2; n=0; tol=abs(root-t(3)); while tolerr n=n+1; if nN disp(迭代次数过大!); return end t(1)=t(2); t(2)=t(3); t(3)=root; f1=fun(t(1)); f2=fun(t(2)); f3=fun(t(3)); d1=(f2-f1)/(t(2)-t(1)); d2=(f3-f2)/(t(3)-t(2)); d3=(d2-d1)/(t(3)-t(1)); B=d2+d3*(t(3)-t(2)); root=t(3)-2*f3/(B+sign(B)*sqrt(B^2-4*f3*

文档评论(0)

wuhuaiyu002 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档