数学实验“欧拉数值算法,Runge-Kutta数值算法”实验报告(内含matlab程序)..docVIP

数学实验“欧拉数值算法,Runge-Kutta数值算法”实验报告(内含matlab程序)..doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数学实验“欧拉数值算法,Runge-Kutta数值算法”实验报告(内含matlab程序).

西京学院数学软件实验任务书 课程名称 数学软件实验 班级 数0901 学号 0912020107 姓名 李亚强 实验课题 欧拉数值算法(显式,隐式,欧拉预估-校正法),Runge-Kutta数值算法 实验目的 熟悉欧拉数值算法(显式,隐式,欧拉预估-校正法),Runge-Kutta数值算法 实验要求 运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成 实验内容 欧拉数值算法(显式,隐式,欧拉预估-校正法) Runge-Kutta数值算法 成绩 教师 实验二十四实验报告 实验名称:欧拉数值算法(显式,隐式,欧拉预估-校正法),Runge-Kutta数值算法。 实验目的:进一步熟悉欧拉数值算法(显式,隐式,欧拉预估-校正法),Runge-Kutta数值算法。 实验要求:运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成程序设计。 实验原理: 欧拉数值算法(显式): 微分方程里最简单的方程形式莫过于一阶常微分方程的初值问题,即: 其中,为常数。 因为其简单但又是求解其他方程的基础,所以发展了许多典型的解法。所有算法中的就是代表上式中,而表示,表示。 简单欧拉法是一种单步递推算法。简单欧拉法的公式如下所示: 简单欧拉法的算法过程介绍如下: 给出自变量的定义域,初始值及步长。 对,计算 欧拉数值算法(隐式): 隐式欧拉法也叫退欧拉法,隐式欧拉法的公式如下所示: 隐式欧拉法是一阶精度的方法,比它精度高的公式是: 隐式欧拉的算法过程介绍如下。 给出自变量的定义域,初始值及步长。 对,用牛顿法或其他方法求解方 得出。 欧拉预估-校正法: 改进欧拉法是一种二阶显式求解法,其计算公式如下所示: Runge-Kutta数值算法: 二阶龙格-库塔法有多种形式,除了改进的欧拉法外,还有中点法。中点法计算公式为: 实验内容: %欧拉数值算法(显式) function [h,k,X,Y,P,REn]=Qeuler1(funfcn,x0,y0,b,n,tol) x=x0; h=(b-x)/n; X=zeros(n,1); y=y0; Y=zeros(n,1); k=1; X(k)=x; Y(k)=y; for k=2:n+1 fxy=feval(funfcn,x,y); delta=norm(h*fxy,inf); wucha=tol*max(norm(y,inf),1.0); if delta=wucha x=x+h; y=y+h*fxy; X(k)=x;Y(k)=y; end plot(X,Y,rp) grid label(自变量 X), ylabel(因变量 Y) title(用向前欧拉(Euler)公式计算dy/dx=f(x,y),y(x0)=y0在[x0,b]上的数值解) end P=[X,Y]; syms dy2, REn=0.5*dy2*h^2; %欧拉数值算法(隐式) function [X,Y,n,P]=Heuler1(funfcn,x0,b,y0,h,tol) n=fix((b-x0)/h); X=zeros(n+1,1); Y=zeros(n+1,1); k=1; X(k)=x0; Y(k,:)=y0; Y1(k,:)=y0; clc,x0,h,y0 for i=2:n+1 X(i)=x0+h; Y(i,:)=y0+h*feval(funfcn,x0,y0); Y1(i,:)=y0+h*feval(funfcn,X(i),Y(i,:)); Wu=abs(Y1(i,:)-Y(i,:)); while Wutol p=Y1(i,:); Y1(i,:)=y0+h*feval(funfcn,X(i),p); Y(i,:)=p; end x0=x0+h; y0=Y1(i,:); Y(i,:)=y0; plot(X,Y,ro) grid on xlabel(自变量 X), ylabel(因变量 Y) title(用向后欧拉公式计算dy/dx=f(x,y),y(x0)=y0在[x0,b]上的数值解) end X=X(1:n+1); Y=Y(1:n+1,:); n=1:n+1; P=[n,X,Y] %欧拉预估-校正法 function [H,X,Y,k,h,P]=gaiEuler(funfcn,x0,b,y0,tol) pow=1/3; if nargin 5 | isempty(tol), tol = 1.e-6; end; if nargin 6 | isempty(trace), trace = 0; end; x=x0; h=0.0078125*(b-x);

文档评论(0)

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

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

1亿VIP精品文档

相关文档