MATLAB-常微分方程求解

这篇具有很好参考价值的文章主要介绍了MATLAB-常微分方程求解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

MATLAB中可以用来求解常微分方程(组)的函数有ode23、 ode23s、 ode23t、 ode23tb 、ode45、ode15s和odel13等,见下表。它们的具体调用方法类似,为了方便后面的描述,

在后面的介绍中将使用solver统一代替它们。

MATLAB-常微分方程求解

函数的具体调用方法如下。

[T,Y] =solver( odefun, tspan,y0)

[T,Y] = solver( odefun,tspan, y0,options)

[T,Y]=soIver( odefun, tspan,yO,options,pl ,p2,...)

在区间tspan=[t0,tf].上,使用初始条件y0,求解常微分方程y'=f(t,y)。其中解向量Y中的每行结果对应于时间向量T中的每个时间点。利用传递给函数odefun的p1, p2, .参数进行求解。solver 函数中涉及的参数见表。

MATLAB-常微分方程求解

odeset函数的用法与optimset函数类似,利用所设置的可选参数进行求解,solver 中options的参数见表。

MATLAB-常微分方程求解
MATLAB-常微分方程求解

MATLAB可以求解3种类型一阶常微分方程,即显式常微分方程、线性隐式常微分方程和完全隐式常微分方程。

显式常微分方程

显式常微分方程的形式为

MATLAB-常微分方程求解

例:显式常微分方程求解实例。

已知微分方程为y"-u(1-y^2)y'+y=0 (y(0)=0,y'(0)=2;t∈[0,30]),分别取μ=3和μ=5求解该方程。

首先对微分方程进行变换得到形式为

MATLAB-常微分方程求解

然后对方程组进行函数描述,并保存为myfun6. 9. m,其内容如下所示。

function output = myfun6.9(t,y ,mu)

output = zeros(2,1);

output(1)=y(2);

output(2)= mu*(1-y(1)^2) *y(2)-y(1);

对方程组进行求解,在命令行窗口中输入如下语句。

>>[t1,y1] =ode45( @ myfun6_ 9,[0 30],[0;2],[],3); %mu=3

[t2,y2]=ode45(@ myfun6 9,[0 30],[0;2],[],5); %mu=5

plot(t1,y1(:,1),'-',t2,y2(:,2),'--')

title( '显式常微分方程的解');

xlabel('t');

ylabel('y ');

legend( 'mu=3',' mu=5');

图形窗口中的输出结果如图所示。文章来源地址https://www.toymoban.com/news/detail-433252.html

MATLAB-常微分方程求解

线性隐式常微分方程

线性隐式常微分方程的形式为

MATLAB-常微分方程求解

例:线性隐式常微分方程求解实例。

已知微分方程(ty^2+1)y'=3y"+y+4(t∈[0,10];y(0)=2),求解该方程。

首先根据微分方程(ty^2+1)y'=3y^3 +y+4和通式4M(1,y)y'=f(t,y),得到:

MATLAB-常微分方程求解

然后对f(1,y)进行函数描述,并保存为myfun6_ 10f. m,其内容如下所示。

function output= myfun6_ 10f(t,y)

output=3* y. ^3+y+4;

对M(t,y)进行函数描述,并保存为myfun6_ 10M. m,其内容如下所示。

function output = myfun6_10M(t,y)

output=t*y. ^2+1;

最后对方程进行求解,在命令行窗口中输人如下语句。.

>>options = odeset( ' RelTol ',le-6, 'OutputFen ',' odeplot ',' Mass ' ,@ myfun6_ 10M);

[t,y] = ode45( @ myfun6_ 10f,[0 10] ,2 ,options);

xlabel('t');

ylabel('y ');

title( '线性隐式常微分方程的解')

图形窗口中的输出结果如图所示。

MATLAB-常微分方程求解

完全隐式常微分方程

完全隐式常微分方程的形式为:

MATLAB-常微分方程求解

例:完全隐式常微分方程求解实例。

已知方程如下求解该方程。

MATLAB-常微分方程求解

首先对方程进行函数描述,并保存为myfun6_ 11. m,其内容如下所示。

function output = myfun6_ 11(t,y ,dydt)

output=t*y. ^2*dydt. ^3-2* y.^3*dydt. ^2+3*t*(t^2+1) *dydt -t^2*y;

其次对方程进行求解,在命令行窗口中输人如下语句。

>>t0=1;

y0=sqrt(3/2);

yp0=0;

[y0,yp0] =decie( @ myfun6_ 11 ,t0,y0,1 ,yp0,0) ;

[t,y]=ode15i( @ myfun6 11,[1 20] ,y0,yp0);

plot(t,y);

xlabel('t');

ylabel('y');

title(完全隐式常微分方程的解');

图形窗口中的输出结果如图所示。

MATLAB-常微分方程求解

到了这里,关于MATLAB-常微分方程求解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 40.利用欧拉法求解微分方程组(matlab程序)

    40.利用欧拉法求解微分方程组(matlab程序)

    1. 简述        求解微分方程的时候,如果不能将求出结果的表达式,则可以对利用数值积分对微分方程求解,获取数值解。欧拉方法是最简单的一种数值解法。前面介绍过MATLAB实例讲解欧拉法求解微分方程,今天实例讲解欧拉法求解一阶微分方程组。 本文理论部分来自知乎

    2024年02月14日
    浏览(8)
  • 【数学建模\MATLAB】掌握用Matlab求解微分方程问题

    【数学建模\MATLAB】掌握用Matlab求解微分方程问题

    d y d t = a y 2 cfrac{dy}{dt}=ay^2 d t d y ​ = a y 2 结果 d 3 y d t 3 = b y cfrac{d^3y}{dt^3}=by d t 3 d 3 y ​ = b y 结果 x 2 + y + ( x − 2 y ) y ′ = 0 x^2+y+(x-2y)yprime=0 x 2 + y + ( x − 2 y ) y ′ = 0 结果: d 2 y d t 2 = a y , 初 始 条 件 为 y ( 0 ) = 5 , y ′ ( 0 ) = 1 cfrac{d^2y}{dt^2}=ay, text初始条件为y(0)=5,yprime(

    2024年02月03日
    浏览(30)
  • matlab使用教程(28)—微分方程(ODE)求解常见问题

    matlab使用教程(28)—微分方程(ODE)求解常见问题

            本博客说明如何将 ODE 解约束为非负解。施加非负约束不一定总是可有可无,在某些情况下,由于方程的物理解释或解性质的原因,可能有必要施加非负约束。仅在必要时对解施加此约束,例如不这样做积分就会失败或者解将不适用的情况。         如果解的

    2024年02月11日
    浏览(11)
  • 欧拉法与梯形法求解微分方程【含matlab源代码】

    欧拉法与梯形法求解微分方程【含matlab源代码】

    本文介绍两种入门级求解微分方程的方法 —— 梯形法与欧拉法。 将上述方程组改写成matlab语言: 一、欧拉法 1.1 向前欧拉公式 1.2 向后欧拉公式     欧拉法求解源代码       欧拉法结果图   二、梯形法    梯形法求解源代码       梯形法结果图    感谢 Miracle 向公众

    2024年02月15日
    浏览(11)
  • 微分方程+传染病模型(指数传播、SI、SIS、SIR模型)+MATLAB求解

    微分方程+传染病模型(指数传播、SI、SIS、SIR模型)+MATLAB求解

    本文为北海的数模课程学习笔记,课程出自微信公众号:数学建模BOOM。 求赞!求收藏!求关注! 微分方程结合传染病模型(如指数传播、SI、SIS、SIR模型)提供了一种用数学公式描述疾病传播动态的方法,有助于理解和预测疾病在人群中的传播路径和速度。 目录 指数传播模

    2024年02月04日
    浏览(10)
  • Fortran 微分方程求解 --ODEPACK

    Fortran 微分方程求解 --ODEPACK

    最近涉及到使用Fortran对微分方程求解,我们知道MATLAB已有内置的函数,比如ode家族,ode15s,对应着不同的求解办法。通过查看odepack的官方文档,我尝试使用了dlsode求解刚性和非刚性常微分方程组。 首先是github网址:https://github.com/jacobwilliams/odepack 具体使用办法: 1.我使用的

    2024年02月11日
    浏览(11)
  • PINN深度学习求解微分方程系列一:求解框架

    PINN深度学习求解微分方程系列一:求解框架

    下面我将介绍内嵌物理知识神经网络(PINN)求解微分方程。首先介绍PINN基本方法,并基于Pytorch框架实现求解一维Poisson方程。 内嵌物理知识神经网络(PINN)入门及相关论文 深度学习求解微分方程系列一:PINN求解框架(Poisson 1d) 深度学习求解微分方程系列二:PINN求解burg

    2023年04月16日
    浏览(10)
  • Simulink基础【1】-弹簧-阻尼模型的常微分方程求解

    Simulink是Matlab软件的框图设计环境,可用于各种动态系统的建模、分析与仿真过程。如:导航制导、通讯、电子、机械、热力学等诸多领域。这些系统在数学角度描述上涉及连续、离散、非线性、时变等用解析方法难以求解的系统,因而采用Simulink进行建模与仿真是指导这些系

    2023年04月08日
    浏览(20)
  • Python和Julia TensorFlow科学计算常微分方程求解器

    常微分方程(ODE)可用于描述动态系统。 从某种程度上来说,我们生活在一个动态系统中,窗外的天气从黎明到黄昏都在变化,我们体内发生的新陈代谢也是一个动态系统,因为随着时间的推移,成千上万的反应和分子被合成和降解。 更正式地说,如果我们定义一组变量,

    2024年02月01日
    浏览(29)
  • matlab解微分方程

    matlab解微分方程

    f=@(变量) 表达式; x1为2 3 4 5;x2为3 4 5 6的情况下求解函数f的值 用“dsolve” step1: 申明自变量和因变量 syms y(x) step2:编程 得到: step1: 申明自变量和因变量 syms y(x) step2:编程 得到 step1.写函数文件 step2.主函数 相当于定义了一个新向量y,然后列 匿名函数 ,方程的 左边都是一阶

    2024年02月13日
    浏览(15)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包