欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    MATLAB解ODE.docx

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

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

    MATLAB解ODE.docx

    MATLAB解ODEMATLAB解ODE 分子二班 张雷 1314057 要求: 介绍MATLAB求解常微分方程初值问题、刚性问题、边值问题,隐式微分方程、延迟微分方程、代数微分方程的功能函数和使用方法,并分别举例说明。含程序和运行结果。 常微分方程的定义: 凡含有参数,未知函数和未知函数导数 (或微分) 的方程,称为微分方程,有时简称为方程,未知函数是一元函数的微分方程称作常微分方程,未知数是多元函数的微分方程称作偏微分方程。微分方程中出现的未知函数最高阶导数的阶数,称为微分方程的阶。定义式如下: 常微分方程的解析解: 有些微分方程可直接通过积分求解。有些常微分方程可用一些技巧,如分离变量法,积分因子法,常数变异法,降阶法等可化为可积分的方程而求得解析解. 线性常微分方程的解满足叠加原理,从而他们的求解可归结为求一个特解和相应齐次微分方程的通解。 一阶常微分方程与高阶微分方程可以互化,已给一个n阶方程 (n-1)设y1=y,y2=y',L,yn=y,可将上式化为一阶方程组 ìy1'=y2ïy'=y23ïïíLïy'=ynïn-1ïy'=f(t,y1,y2,L,yn) în 所以一阶微分方程组与高阶常微分方程的理论与方法在许多方面是相通的,一阶常系数线性微分方程组也可用特征根法求解。 y(n)=f(t,y',y",L,y(n-1)常微分方程的数值解: 除常系数线性微分方程可用特征根法求解,少数特殊方程可用初等积分法求解外,大部分微分方程无限世界,应用中主要依靠数值解法。 我们学过的有向前欧拉公式、向后欧拉公式、龙格-库塔公式、Adams公式等等等等。这其中,包含显格式、隐格式,单步法、多步法。 这些方法如果通过手工计算,费时费力,而且难免出错。使用Matlab进行计算,解决常微分方程问题就显示出优越性。 dsolve函数 在MATLAB中,由函数dsolve解决常微分方程的求解问题,其具体格式如下: r = dsolve('eq1,eq2,.', 'cond1,cond2,.', 'v') 'eq1,eq2,.'为微分方程或微分方程组,'cond1,cond2,.',是初始条件或边界条件,'v'是独立变量,默认的独立变量是't'。 函数dsolve用来解符号常微分方程、方程组,如果没有初始条件,则求出通解,如果有初始条件,则求出特解。 求通解 隐式微分方程 求解微分方程 输入语句:y=dsolve('Dy-x2-y','x') (以字符串形式) 输出结果:y =C2*exp(x) - 2*x - x2 2 边界问题 求解微分方程 输入语句: syms x y; y=dsolve('x*Dy+y-x=0','y(1)=2*exp(1)','x') 输出语句: y =(x2/2 + 2*exp(1) - 1/2)/x 求微分方程 输入语句: syms x y; y=dsolve('D2y-x=0','Dy(0)=2','y(0)=1','x') 输出语句: y =x3/6 + 2*x + 1 求解微分方程组 求 输入语句:y1,y2=dsolve('Dy1=4-2*y1','Dy2=2*x-y2','x') 输出语句;y1 =exp(-2*x)*(C10 + 2*exp(2*x) y2 =exp(-x)*(C11 + 2*exp(x)*(x - 1) 问题四:初值问题 求解 输入语句:y=dsolve('Dy=4-2*x*sin(x)','y(0)=1','x') 输出语句:y =4*x - 2*sin(x) + 2*x*cos(x) + 1 数值解 ode23、ode45等功能函数 MATLAB提供了7个常微分方程求解器,分别是ode45, ode23, ode113, ode15s, ode23s, ode23t, ode23tb,其中前3个适用于求解非刚性问题,后4个适用于刚性问题。 基于龙格-库塔法,MATLAB提供了求常微分方程的数值解的函数。 一般调用格式为: t,y=ode23(filename,tspan,y0) t,y=ode45(filename,tspan,y0) 其中filename是定义f(t,y)的函数文件名,该函数文件必须返回一个列向量。,tspan形式为t0,tf,表示求解区间,y0是初始状态列向量。t和y分别给出时间限量和相应的状态向量。 对于两者区别:ode是Matlab专门用于解微分方程的功能函数;solver有变步长和定步长两种类型,不同类型有着不同的求解器。ode45求解器属于变步长的一种,采用Runge-Kutta算法;和他采用相同算法的变步长求解器还有ode23。 ode45表示采用四阶,五阶runge-kutta单步算法,截断误差为(x)3。 初值问题 输入语句 function y = fun_01(x,y ) y=x2+y end t0=0;tf=1; %确定t的范围 y0=2; t,y=ode23('fun_01',t0,tf,y0); T,Y = ode45(odefun,tspan,y0,options) options 是求解参数设置,可以用odeset在计算前设定误差,输出参数,事件等。 ode23、ode45都是变步长算法,但是也可以通过对tspan的设置,实现定步长计算。 还以上题为例, 输入: t=0:0.5:1 ; %确定t的范围和步长 y0=2; t,y=ode23('fun_01',t,y0) 输出结果: y = 2.0000 3.3448 5.8729 一些特殊情况 延迟微分方程: 延迟微分方程,数学领域中的一大模块。微分方程模型的共同特点是:系统状体变量的导数不仅依赖于系统当前的状态,而且依赖于系统在过去某一时刻或某一历史时期的状态。 在数学领域中,时滞微分方程, 或延时微分方程(DDE) 是一类微分方程, 其中未知函数的在确定时刻的导数由先前时刻函数所决定. 微分代数方程: 微分代数方程就是几个微分方程和纯代数方程组成的一个系统。和偏微分方程类似,微分代数方程也很难找到精确的结果。 刚性问题: 常微分方程中同时包含有快变分量和慢变分量,二者变化速度相差非常大的量级,这种特点在数学上称为刚性。 描述这种过程的常微分方程组称为刚性方程组。 稳定步长h受绝对值最大的特征值 |max控制,允许步长很小。 过程趋于稳定的时间由绝对值最小的特征值控制。但由于稳定性要求,仍要用小步长,计算量巨大,误差积累的影响也随着计算步数的增加越来越严重。 对于这些特殊情况,也可以通过Matlab进行求解 微分代数方程: 用矩阵形式表示出该DAEs 最后一个方程不是微分方程而是一个代数方程(这就是为什叫DAE的原因),其实我们可以将它视为对三个状态变量的约束。 1. odefun=(t,x)-0.2*x(1)+x(2)*x(3)+0.3*x(1)*x(2); 2. 2*x(1)*x(2)-5*x(2)*x(3)-2*x(2)*x(2); 3. x(1)+x(2)+x(3)-1;%微分方程组 4. M=1 0 0;0 1 0;0 0 0;%质量矩阵 5. options=odeset('mass',M);%对以DAE问题,mass属性必须设置 6. x0=0.8;0.1;0.1;%初值 7. t,x=ode15s(odefun,0 20,x0,options);%这里好像不能使用ode45 8. figure('numbertitle','off','name','DAE demoby Matlabsky') 9. plot(t,x) 10. legend('x1(t)','x2(t)','x3(t)') (其实,我真没看懂,只是复制了一下) 刚性问题: MATLAB提供了7个常微分方程求解器,分别是ode45, ode23, ode113, ode15s, ode23s, ode23t, ode23tb,其中前3个适用于求解非刚性问题,后4个适用于刚性问题。 1. odefun=(t,x)0.04*(1-x(1)-(1-x(2)*x(1)+0.0001*(1-x(2)2 2. -1e4*x(1)+3000*(1-x(2)2; 3. x0=0 1; 4. tspan=0 100; 5. options=odeset('reltol',1e-6,'abstol',1e-8); 6. tic;t2,y2=ode15s(odefun,tspan,x0,options);toc 7. disp('ode15s计算的点数' num2str(length(t2)

    注意事项

    本文(MATLAB解ODE.docx)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

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




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开