欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    数值计算二分法简单迭代法Newton迭代法弦截法割线法双点弦法.docx

    • 资源ID:644825       资源大小:149.66KB        全文页数:18页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数值计算二分法简单迭代法Newton迭代法弦截法割线法双点弦法.docx

    1、数值计算二分法简单迭代法Newton迭代法弦截法割线法双点弦法本科生实验报告实验课程 数值计算方法 学院名称 信息科学与技术学院 专业名称 计算机科学与技术 学生姓名 学生学号 指导教师 实验地点 实验成绩 二 一六 年 五 月 二一六 年 五 月实验一 非线性方程求根1.1问题描述实验目的:掌握非线性方程求根的基本步骤及方法,。实验内容:试分别用二分法、简单迭代法、Newton迭代法、弦截法(割线法、双点弦法),求 x5-3x3+x-1= 0 在区间 -8,8上的全部实根,误差限为10-6。要求:讨论求解的全过程,对所用算法的局部收敛性,优缺点等作分析及比较, 第2章 算法思想2.1二分法思

    2、想:在函数的单调有根区间内,将有根区间不断的二分,寻找方程的解。步骤: 1.取中点mid=(x0+x1)/22.若f(mid)=0,则mid为方程的根,否则比较与两端的符号,若与f(x0)异号,则根在x0,mid之间,否则在mid,x1之间。3并重复上述步骤,直达达到精度要求,则mid为方程的近似解。 2.2 简单迭代法思想:迭代法是一种逐次逼近的方法,它是固定公式反复校正跟的近似值,使之逐步精确,最后得到精度要求的结果。步骤:1.构造迭代公式f(x),迭代公式必须是收敛的。 2.计算x1,x1=f(x0). 3.判断|x1-x0|是否满足精度要求,如不满足则重复上述步骤。 4输出x1,即为方

    3、程的近似解。2.3 Newton迭代法思想:设r是的根,选取作为r的初始近似值,过点做曲线的切线L,L的方程为,求出L与x轴交点的横坐标,称x1为r的一次近似值。过点做曲线的切线,并求该切线与x轴交点的横坐标,称为r的二次近似值。重复以上过程,得r的近似值序列,其中,称为r的次近似值步骤:1.计算原函数的导数f(x);构造牛顿迭代公式 2.计算 ,若f(x0)=0,退出计算,否则继续向下迭代。 3.若|x1-x0|满足精度要求,x1即为方程的近似解。2.4弦截法思想:为加速收敛,改用两个端点都在变动的弦,用差商替代牛顿迭代公式的导数f(x)。步骤: 1.构造双点弦法的公式 2.计算x2=x1-

    4、f(x1)(x1-x0)/f(x1)-f(x0);3.判断f(x2)是否满足精度要求,若没有则按照上述步骤继续迭代,否则输出x2.x2即为方程的近似解。 第3章 测试结果及分析 测试结果函数图像函数 Y=x5-3x3+x-1 二分法(表1-1,1-2,1-3)-1.6,-1.3kxkkxkkxk0-1.455-1.5015610-1.504931-1.5256-1.5039111-1.5052-1.48757-1.5050812-1.505043-1.506258-1.5044913-1.505064-1.496889-1.5047914-1.50507 表1-1 区间-1.2,-0.9kxk

    5、kxkkxk0-1.055-0.99843710-1.000051-0.9756-1.0007811-0.9999762-1.01257-0.99960912-1.000013-0.993758-1.000213-0.9999944-1.003129-0.99990214-1表1-2区间1.5,1.8kxkkxkkxk01.6571.69102141.6902911.72581.69043151.6902921.687591.69014161.6902931.70625101.69028171.6902841.69687111.69036181.6902851.69219121.6903261

    6、.68984131.6903表1-3简单迭代法(表2-1.2-2.2-3)初值-1.5kxkkxkkxk1-1.57-1.5043513-1.504932-1.502178-1.5045314-1.504973-1.502879-1.50466151.504994-1.5034110-1.5047616-1.505015-1.5038111-1.5048317-1.505046-1.5041212-1.5048918-1.50505表2-1初值-1kx1-12-1表2-2初值1.6 结果 x=1.69028kxkkxkkxk11.681.68862151.6902321.6566991.689

    7、27161.6902531.66987101.68967171.6902741.6779111.68991181.6902751.68278121.69006191.6902861.68573131.69015201.6902871.68753141.6902表2-3牛顿迭代法(表3-1.3-2,3-3)初值-1.5 结果 x=-1.50507kxkkxk1-1.54-1.505042-1.504715-1.505063-1.504976-1.50507表3-1初值-1 结果 x=-1.50507kx1-12-1表3-2初值1.6 结果 x=1.69028kxkkxk11.651.690242

    8、1.6860261.6902731.6889371.6902841.6898581.69028表3-3双点弦法(表4-1.4-2,4-3)区间-1.6,-1.3 结果 x=-1.50507 kxkf(xk)kxkf(xk)1-1.50.031255-1.506670.07845662-1.661490.3765026-1.505-0.0100793-1.47175-1.563227-1.505070.0004409884-1.4920.1868018-1.505072.30387e-006表4-1区间-1.2,-0.9 结果 x= -1 kxkf(xk)1-1.013930.04156782-

    9、1.00020.0006077773-0.999999-3.11969e-0064-12.11001e-010表4-2区间1.5,1.8 结果 x=1.69028kxkf(xk)11.64403-0.67645521.68071-0.15110631.691260.015798841.69027-0.00031351551.69028-6.3006e-007表4-3 从测试结果可以看出二分法和简单迭代法的收敛速度远大于牛顿迭代和弦截法的收敛速度。二分法和简单迭代法的公式易于构造和计算,牛顿迭代法虽然收敛高,但要求导数,计算的复杂度高!双点弦法随稍慢于牛顿跌代法,可以用差商代替牛顿迭代法中的导数

    10、,降低了计算的复杂度!附录:源程序清单#include#includeusing namespace std;double foot =0.3; /定义寻根步长int a=-8,b=8;double *rn=new double5; /解的区间double *r = new double5; / 方程近似解int m=0; /根的个数int x_count; double precision=0.000001; /精度要求/函数的表达式(x5-3x3+x-1)double f(double x) return (pow(x,5)-3*pow(x,3)+x-1);void init() /根据函

    11、数图像确定根的区间和迭代初值 r0=-1.5; r1=-1; r2=1.6; rn0=-1.6; rn1=-1.2; rn2=1.5;/寻找根的区间 void search() /若没有给出区间和初值,进行逐步搜索有根区间 for(int i=0;i*foot-88;i+) if(f(i*foot-8)*f(i+1)*foot-8)precision) mid = (a+b)/2; if(f(a)*f(mid)=0) b=mid; /判断与端点函数值得符号 else a=mid; coutmidendl; rx_count+=mid; return mid; /返回最终结果 /=简单迭代法=

    12、/构造迭代公式double fitera(double x) double result=0; double xx=3*pow(x,3)-x+1; if(xx=0) xx=-xx; return pow(xx,1.0/5.0)*(-1); else return pow(xx,1.0/5.0); /简单迭代double itera(double x0) coutx0precision) x0=x1; x1=fitera(x0); /没有到达精度要求继续迭代 coutx1precision) x0=x1; if (newtonitera(x0)=-1) break; x1=newtonitera

    13、(x0); /继续迭代 coutx1endl; return x1; /返回最终结果/=双点弦法迭代=/构造弦截法的迭代公式double twopointchord_f(double x0,double x1) return x1-(f(x1)/(f(x1)-f(x0)*(x1-x0);/双点弦法迭代double twopointchord(double x0,double x1) double x3=twopointchord_f(x0,x1); coutx3precision) coutf(x3)f(x3)endl; /输出x3的函数值 x0=x1; x1=x3; x3=twopointc

    14、hord_f(x0,x1); /没有到达精度要求继续迭代 / coutx3endl; coutf(x3)endl; return x3; /返回最终结果/测试void main()init(); /初始化区间和迭代初值/* 测试代码 输出每次的迭代结果和最终结果 cout-二分法-endl;for(int i =0;i3;i+)double result=0;cout有根区间为rni rni+footendl;result=Dichotomy(rni,rni+foot); /将区间端点带入公式cout求得近似解为resultendl;cout-迭代法-endl;for(i =0;i3;i+)d

    15、ouble result=0;cout有根区间为rni rni+footendl;double x0 =ri; /取得初值result=itera(x0); /带入公式cout求得近似解为resultendl;cout-牛顿迭代-endl;for(i =0;i3;i+)double result=0;cout有根区间为rni rni+footendl;double x0 =ri; /取得初值result=newton(x0); /带入公式 cout求得近似解为resultendl;cout-弦截法-endl;for(i =0;i3;i+)double result=0;cout有根区间为rni

    16、 rni+footendl; result=twopointchord(rni,rni+foot); /将区间端点带入公式cout求得近似解为resultendl;/*学生实验 心得 在这次实验中,通过编程将二分法、简单迭代法、Newton迭代法、弦截法(割线法、双点弦法)以代码的方式实现,这不仅是一次实践过程,更是对这些求解方程的方法的深入理解,体会们各自的算法思想。也提高的我对数值计算中的经典方法其中蕴藏的算法思想的兴趣,这些思想方法对以后的问题的解决以及编程思想都是很有帮助的。 虽然在实验过程中遇到了一些问题,但是通过查询资料以及不断的调试程序都得以解决。这也让我认识到只要深入理解,坚持不懈,就一定能够成功的。我会将这次的实验的宝贵经验实践到以后的学习中,希望能在不断的锻炼中提升自己!学生(签名): 年 月 日指导教师评语成绩评定:指导教师(签名): 年 月 日


    注意事项

    本文(数值计算二分法简单迭代法Newton迭代法弦截法割线法双点弦法.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开