




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、课程名称数值计算方法实验项目名称常微分方程初值问题的数值解法实验成绩 指导老师(签名 ) 日期2015/12/16一. 实验目的和要求1. 用Matlab软件掌握求微分方程数值解的欧拉方法和龙格-库塔方法;2. 通过实例学习用微分方程模型解决简化的实际问题。二. 实验内容和原理编程题2-1要求写出Matlab源程序(m文件),并有适当的注释语句;分析应用题2-2 , 2-3 ,2-4 , 2-5要求将问题的分析过程、Matlab源程序和运行结果和结果的解释、算法的分析写在实验报告上。2-1编程编写用向前欧拉公式和改进欧拉公式求微分方程数值解的Matlab程序,问题如下:在区间a,b内(N 1)
2、个等距点处,逼近下列初值问题的解,并对程序的每一句添上注释语 句。y f (x, y) a x b y(a) y°Euler 法 y=euler(a,b,n,y0,f,f1,b1)改进 Euler 法 y=eulerpro(a,b,n,y0,f,f1,b1)2-2分析应用题假设等分区间数 n 100,用欧拉法和改进欧拉法在区间t 0,10内求解初值问题y(t) y(t) 20y(0)10并作出解的曲线图形,同时将方程的解析解也画在同一张图上,并作比较,分析这两种方法的精度。2-3分析应用题用以下三种不同的方法求下述微分方程的数值解,取h 10y y 2xy(0) 1画出解的图形,与精
3、确值比较并进行分析。1) 欧拉法;2) 改进欧拉法;3) 龙格库塔方法;2-4分析应用题考虑一个涉及到社会上与众不同的人的繁衍问题模型。假设在时刻t(单位为年),社会上有人口 x(t)人,又假设所有与众不同的人与别的与众不同的人结婚后所生后代也是与众 不同的人。而固定比例为r的所有其他的后代也是与众不同的人。如果对所有人来说出生率假定为常数b,又如果普通的人和与众不同的人的婚配是任意的,则此问题可以用微分方程表示为:dP® rb(1 p(t)dt其中变量p(t) xi (t) x(t)表示在时刻t社会上与众不同的人的比例,x(t)表示在时刻t人口中与众不同的人的数量。1) 假定p(0
4、)0.01,b 0.02和r 0.1,当步长为h 1年时,求从t 0到t 50解p(t)的近似值,并作出近似解的曲线图形。2) 精确求出微分方程的解p(t),并将你当t 50时在分题(b)中得到的结果与此时的精确值 进行比较。【MATLAB相关函数】求微分方程的解析解及其数值的代入dsolve( subs (expr, x,y, egn1', egn2', L x'), x1,y1,)其中egni '表示第i个方程, x '表示微分方程中的自变量,默认时自变量为t。subs命令中的expr、x、y为符合型表达式,x、y分别用数值x1、x2代入。>&
5、gt; syms x y z>> subs('x+y+z',x,y,z,1,2,3)ans =6>> syms x>> subs('xA2',x,2) ans =s=dsolve( Dy 1 y 2' , y(0)1' , x')ans =tan(x 1 4 pi)4>> syms x>> subs(s,x,2) ans =右端函数f (x, y)的自动生成f= in li ne('expr' , ' var1 ' ,' var2 '
6、;,)其中expr '表示函数的表达式,varl ' ,var2 '表示函数表达式中的变量,运行该函数,生成一个新的函数表达式为 f (varl, var2, )。>> f=i nlin e('x+3*y','x','y')Inline fun cti on: f(x,y) = x+3*y>> f(2,3) ans =114,5阶龙格-库塔方法求解微分方程数值解t,x=ode45(f,ts,x0,optio ns)其中f是由待解方程写成的m文件名;x0为函数的初值;t,x分别为输出的自变量和函数值(
7、列向量),t的步长是程序根据误差限自动选定的。若ts=t0,t1,t2,tf,则输出在自变量指定值,等步长时用ts=tO:k:tf ,输出在等分点;options用于设定误差限(可以缺省,缺省时设定为相对误差10 3,绝对误差10 6),程序为:options=odeset( reltol ' ,rt, ' abstol ' ,at),这里 rt,at分别为设定的相对误差和绝对误差。常用选项见下表。选项名功能可选值省缺值AbsTol设定绝对误差正数1e 6RelTol设定相对误差正数1e 3In itialStep设疋初始步长正数自动MaxStep2 rc 宀 rH x
8、 r. m 设定步长上界正数tspan/10MaxOrder设定ode15s的最高阶数1,2,3,4,55Stats显示计算成本统计on,offoffBDF设定ode15s是否用反向差分on,offoff例:解微分方程y y 20 t 4yy(0) 1在命令窗口执行odefun = inline ( ' y 2* t y ' ,' t' ,' y ');t,y ode45(odefun,0,4,1) ;t,y ans =0plot( t, y, o- ' ,)% 解函数图形表示ode45(odefun,0,4,1) % 不用输出变量,则直
9、接输出图形 t,y ode45(odefun,0 : 4,1) ; t,yans =0操作方法与实验步骤(包括实验数据记录和处理)2-1 编程编写用向前欧拉公式和改进欧拉公式求微分方程数值解的 Matlab 程序,问题如下: 在区间 a,b 内 (N 1)个等距点处,逼近下列初值问题的解,并对程序的每一句添上注释语 句。y f(x, y) a x b y(a) y°Euler 法 y=euler(a,b,n,y0,f,f1,b1) 改进 Euler 法 y=eulerpro(a,b,n,y0,f,f1,b1)Euler 法 y=euler(a,b,n,y0,f,f1,b1) y=ze
10、ros(1,n+1);y(1)=y0;h=(b-a)/n;x=a:h:b;for i=1:n;y(i+1)=y(i)+h*f(x(i),y(i);end plot(x,y)hold on% 求微分方程的精确解 x1=linspace(a,b,100);' 精确解为 ' s=dsolve(f1,b1,'x') syms x y1=zeros(1,100);fori=1:100y1(i)=subs(s,x,x1(i);endplot(x1,y1,'r')title(' 红色代表精确解 ')改进 Euler 法y=eulerpro(a,
11、b,n,y0,f,f1,b1) % 求微分方程的数值解 y=zeros(1,n+1);y(1)=y0;h=(b-a)/n;x=a:h:b;fori=1:n;T1=f(x(i),y(i);T2=f(x(i+1),y(i)+h*T1); y(i+1)=y(i)+(h/2)*(T1+T2);endplot(x,y)hold on% 求微分方程的精确解x1=linspace(a,b,100);' 精确解为 ' s=dsolve(f1,b1,'x') syms x y1=zeros(1,100);for i=1:100y1(i)=subs(s,x,x1(i);endplo
12、t(x1,y1,'r')title(' 红色代表精确解 ')2-2 分析应用题0,10 内求解初值问题并作比较, 分析这两种方法假设等分区间数 n 100 ,用欧拉法和改进欧拉法在区间 ty (t) y(t) 20 y(0) 10并作出解的曲线图形, 同时将方程的解析解也画在同一张图上, 的精度。(1) 向前欧拉法>> euler(0,10,100,10,inline('y-20','x','y'),'Dy=y-20','y(0)=10') ans =精确解为s =20
13、- 10*exp(x)ans =Columns 1 through 8+005 *Columns 9 through 16Columns 17 through 24Columns 25 through 32Columns 33 through 40Columns 41 through 48Columns 49 through 56Columns 57 through 64Columns 65 through 72Columns 73 through 80Columns 81 through 88Columns 89 through 96Columns 97 through 101(2)改进欧拉
14、法>> eulerpro(0,10,100,10,inline('y-20','x','y'),'Dy=y-20','y(0)=10') ans =精确解为s = 20 - 10*exp(x)ans = +005 *Columns 1 through 8Columns 9 through 16Columns 17 through 24Columns 25 through 32Columns 33 through 40Columns 41 through 48Columns 49 through 56Co
15、lumns 57 through 64Columns 65 through 72Columns 73 through 80Columns 81 through 88Columns 89 through 96Columns 97 through 101改进欧拉法的精度比向前欧拉法更高。2-3分析应用题用以下三种不同的方法求下述微分方程的数值解,取h 10y y 2x 0 x 1 y(0) 1画出解的图形,与精确值比较并进行分析。1) 欧拉法;2) 改进欧拉法;2-4分析应用题考虑一个涉及到社会上与众不同的人的繁衍问题模型。假设在时刻t(单位为年),社会上有人口 x(t)人,又假设所有与众不同的人
16、与别的与众不同的人结婚后所生后代也是与众 不同的人。而固定比例为r的所有其他的后代也是与众不同的人。如果对所有人来说出生率假定为常数b,又如果普通的人和与众不同的人的婚配是任意的,则此问题可以用微分方程表示为:dp(t)rb(1 p(t)dt其中变量p(t) Xi (t) x(t)表示在时刻t社会上与众不同的人的比例,x(t)表示在时刻t人口中与众不同的人的数量。1) 假定p(0) 0.01,b 0.02和r 0.1,当步长为h 1年时,求从t 0到t 50解p(t)的近 似值,并作出近似解的曲线图形。2) 精确求出微分方程的解p(t),并将你当t 50时在分题(b)中得到的结果与此时的精确值 进行比较。1)>>euler(0,50,50,i nlin e(”,'t','p'),'Dp=','p(0)=1')ans =精确解为1 - 99/(100*exp(x/500) ans =Columns 1 through 8Columns 9 t
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030年中国铅锌行业十三五投资分析及发展风险评估报告
- 2025-2030年中国针织面料市场运营状况与发展潜力分析报告
- 2025-2030年中国酵母核糖核酸市场运行趋势及投资战略研究报告
- 2025-2030年中国速溶固体饮料市场发展趋势及前景调研分析报告
- 2025-2030年中国豆腐市场运行状况及发展趋势分析报告
- 2025-2030年中国血液透析机市场运营现状及发展前景规划分析报告
- 2025-2030年中国脱咖啡因绿茶市场发展策略规划分析报告
- 2025-2030年中国美白护肤市场运行状况及投资战略研究报告
- 2025年上海市建筑安全员-A证考试题库及答案
- 2025-2030年中国米酒市场运行动态及投资战略研究报告
- 2025年中华工商时报社事业单位招聘12人历年高频重点模拟试卷提升(共500题附带答案详解)
- 安全生产事故调查与案例分析(第3版)课件 吕淑然 第1-4章 绪论-应急预案编制与应急管理
- 中小学课件人造卫星课件
- 新版冀教版(冀人版)科学五年级下册全册教案
- 钢楼梯计算(自动版)
- 社区医院建设标准
- 个人所得税税率表【自动提取税率计算】
- 浙美版小学美术五年级下册课件1画家故居
- 中国作家协会入会申请表
- 荧光绿送货单样本excel模板
- 水土保持治理效益计算
评论
0/150
提交评论