- 1、本文档共49页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
matlab在数值分析中的应用Runge_kutta
求解: x0=[1.2; 0; 0; -1; tic, [t,y]=ode45(apolloeq,[0,20],x0); toc elapsed_time = 0.8310 length(t), plot(y(:,1),y(:,3)) ans = 689 得出的轨道不正确, 默认精度RelTol设置 得太大,从而导致的 误差传递,可减小该 值。 改变精度: options=odeset; options.RelTol=1e-6; tic, [t1,y1]=ode45(apolloeq,[0,20],x0,options); toc elapsed_time = 0.8110 length(t1), plot(y1(:,1),y1(:,3)), ans = 1873 min(diff(t1)) ans = 1.8927e-004 plot(t1(1:end-1),… diff(t1)) 例: x0=[1.2; 0; 0; -1; tic, [t1,y1]=rk_4(apolloeq,[0,20,0.01],x0); toc elapsed_time = 4.2570 plot(y1(:,1),y1(:,3)) % 绘制出轨迹曲线 显而易见,这样求解 是错误的,应该采用 更小的步长。 tic, [t2,y2]=rk_4(apolloeq,[0,20,0.001],x0); toc elapsed_time = 124.4990 %计算时间过长 plot(y2(:,1),y2(:,3)) % 绘制出轨迹曲线 严格说来某些点仍不 满足10-6的误差限, 所以求解常微分方程 组时建议采用变步长 算法,而不是定步长 算法。 例: 用MATLAB符号工具箱求解, 令 % syms x1 x2 x3 x4 [dx,dy]=solve(dx+2*x4*x1=2*dy, dx*x4+ … 3*x2*dy+x1*x4-x3=5,dx,dy) dx = -2*(3*x4*x1*x2+x4*x1-x3-5)/(2*x4+3*x2) dy = (2*x4^2*x1-x4*x1+x3+5)/(2*x4+3*x2) 对于更复杂的问题来说,手工变换的难度将很大,所以如有可能,可采用计算机去求解有关方程,获得解析解。如不能得到解析解,也需要在描写一阶常微分方程组时列写出式子,得出问题的数值解。 7.3特殊微分方程的数值解 7.3.1 刚性微分方程的求解 刚性微分方程 一类特殊的常微分方程,其中一些解变化缓慢,另一些变化快,且相差悬殊,这类方程常常称为刚性方程。 MATLAB采用求解函数ode15s(),该函数的调用格式和ode45()完全一致。 [t,x]=ode15s(Fun,[t0,tf],x0,options,p1,p2,…) 例: %计算 h_opt=odeset; h_opt.RelTol=1e-6; x0=[2;0]; t_final=3000; tic, mu=1000; [t,y]=ode15s(vdp_eq,[0,t_final],x0,h_opt,mu); toc elapsed_time = 2.5240 %作图 plot(t,y(:,1)); figure; plot(t,y(:,2)) y(:,1)曲线变化较平滑, y(:,2)变化在某些点上较快。 例: 定义函数 function dy=c7exstf2(t,y) dy=[0.04*(1-y(1))-(1-y(2))*y(1)+0.0001*(1-y(2))^2; -10^4*y(1)+3000*(1-y(2))^2]; 方法一 tic,[t2,y2]=ode45(c7exstf2,[0,100],[0;1]); toc elapsed_time = 229.4700 length(t2), plot(t2,y2) ans = 356941 步长分析: format long, [min(diff(t2)), max(diff(t2))] ans = 0.00022220693884 0.00214971787184 plot(t2(1:end-1),diff(t2)) 方法二,用ode15s()代替ode
您可能关注的文档
- ISO9001内审员培训_常州质量人.ppt
- GetSmart_中文介绍.ppt
- IMF与世界银行_资本无垠小组.ppt
- IT行业管理咨询_中大咨询.ppt
- ITP概念的更新_中文版.ppt
- JAVA全套简明教程ch05_方法.ppt
- i湖南省公开课课件蒋芳〔新1〕.ppt
- java学习课件第2章数据类型_1.ppt
- java程序设计教程第3章_Java程序基础.ppt
- DLP及其应用–3D打印.ppt
- 2025年文化创意产业园区建设项目申请报告:文化创意产业园区与文化产业园区合作模式.docx
- TXZBX-0012-2025电气系统分布式能源接入与协调控制技术规程.pdf
- 智能家居行业生态构建与用户接受度提升措施研究报告.docx
- 交通运输行业2025年数字化转型投资趋势报告.docx
- 城市老旧街区改造与社区和谐稳定的关联性分析报告.docx
- 2025年二手奢侈品市场交易活跃度分析报告:消费者心理认知与市场细分策略.docx
- 房地产企业多元化经营与产业链协同效应研究报告(2025年版).docx
- 2025年公共卫生设施建设与城市社区稳定风险的评估与应对策略研究报告.docx
- 智慧公交系统2025年智能交通与城市交通服务评估报告.docx
- 海上风电产业技术创新与产业竞争力提升研究报告.docx
文档评论(0)