MATLAB-常微分方程求解

news2024/10/6 4:01:44

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

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

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

[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 函数中涉及的参数见表。

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

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

显式常微分方程

显式常微分方程的形式为

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

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

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

然后对方程组进行函数描述,并保存为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');

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

线性隐式常微分方程

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

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

已知微分方程(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),得到:

然后对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( '线性隐式常微分方程的解')

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

完全隐式常微分方程

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

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

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

首先对方程进行函数描述,并保存为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(完全隐式常微分方程的解');

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/149573.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

简述 synchronized 和 ReentrantLock 之间的区别?

相同点 synchronized 和 ReentrantLock 都是 Java 中提供的可重入锁。 可重入锁:什么是 “可重入”,可重入就是说某个线程已经获得某个锁,可以再次获取锁而不会出现死锁。 不同点 用法不同:synchronized 可以用来修饰普通方法、静…

红中私教:使用wamp64配置靶场

应朋友请求,出一篇配服务器的教程 首先安装软件 https://cowtransfer.com/s/9db1b9ad2c1d44 点击链接查看 [ wampserver3.3.0_x64.exe ] ,或访问奶牛快传 cowtransfer.com 输入传输口令 pgs341 查看; 接下来,使用HbuilderX打开我…

基于Paddle实现实例分割

百度的Paddle这几年发展十分迅速,而且文档十分齐全,涉及到机器视觉的多个应用领域,感觉还是非常牛的,各种backbone,损失函数、数据增强手段以及NMS等,整体感觉复现的很全面,值得推荐学习。 本…

搭建Redisson流程以及解读MutilLock源码解决分布式锁的主从一致性问题

搭建Redisson流程以及解读MutilLock源码解决分布式锁的主从一致性问题1、搭建3台独立主节点的redis服务2、创建java redisson客户端3、获取分布式锁4、分析获取锁源码getMultiLocktryLock(long waitTime, long leaseTime, TimeUnit unit)5、总结1、搭建3台独立主节点的redis服务…

Apache Shiro教程(3)

shiro自定义realms及加密md5salt教程 1、添加pom 文件 <dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-spring</artifactId><version>1.9.1</version> </dependency>2、创建realms自定义文件 import o…

【树莓派/入门】使用MAX30102测量血氧浓度

说在前面 树莓派版本&#xff1a;4b血氧模块&#xff1a;MAX30102树莓派系统&#xff1a;Linux raspberrypi 5.15.76-v8 #1597 SMP aarch64 GNU/Linuxpython版本&#xff1a;3.9.2 模块详情 某宝上买的MAX30102模块&#xff0c;包含杜邦线 准备工作 开启树莓派的GPIO&#x…

java 高级面试题整理

SpringMVC的控制器是单例的吗? 第一次&#xff1a;类是多例&#xff0c;一个普通属性和一个静态属性 总结 尽量不要在controller里面去定义属性&#xff0c;如果在特殊情况需要定义属性的时候&#xff0c;那么就在类上面加上注解Scope("prototype")改为多例的模式…

English Learning - L1-9 时态(中) 2023.1.3 周二

这里写目录标题8 时态8.1 一般时态&#xff08;三&#xff09;一般将来时核心思维&#xff1a;预测&#xff0c;计划&#xff0c;意愿will 和 be going to 的区别将来时的其它表示方式进行时表将来be about to (5 分钟之内)8.2 进行时态核心思维&#xff1a;持续有限的进行&…

黑苹果解决5500xt等navi14显卡引导二阶段黑屏几秒的问题

首先说结论&#xff1a;在注入缓冲帧FB Name的前提下&#xff0c;往显卡注入CFG_LINK_FIXED_MAP参数&#xff0c;类型为Number&#xff0c;值为1。注意一定要注入FB Name&#xff0c;注入FB Name&#xff0c;注入FB Name的前提下&#xff01;&#xff01;我试过不注入FB Name直…

【安全硬件】Chap.5 如何检测芯片中硬件木马?硬件木马的类型有哪些?检测硬件木马的技术

【安全硬件】Chap.5 如何检测芯片中硬件木马&#xff1f;硬件木马的类型有哪些&#xff1f;检测硬件木马的技术前言1. 硬件木马的种类1.1 硬件木马1.2 硬件木马的区分1.1 物理特性类别硬件木马——Physical hardware trojans1.2 激活特性类别硬件木马——Activation1.3 动作特性…

Kafka快速入门

文章目录安装部署集群规划集群部署kafka群起脚本Kafka命令行操作主题命令行操作生产者命令行操消费者命令行操作安装部署 集群规划 集群部署 官方下载地址&#xff1a;http://kafka.apache.org/downloads.html上传安装包到02的/opt/software目录下 [atguiguhadoop02 softwar…

5.hadoop系列之HDFS NN和2NN工作机制

1.第一阶段&#xff1a;NameNode启动 1.第一次启动NameNode格式化后&#xff0c;创建Fsimage和Edits文件&#xff0c;如果不是第一次启动&#xff0c;直接加载Fsimage和Edits到内存 2.客户端对元数据进行增删改请求 3.NameNode记录操作日志&#xff0c;更新滚动日志 4.NameNod…

elasticsearch-head使用问题汇总

1、elasticsearch-head数据预览、基本查询、复合查询模块无法查询es文档记录&#xff08;1&#xff09;解决办法复制vendor.jsdocker cp elasticsearch-head1:/usr/src/app/_site/vendor.js vendor.js修改vendor.js第6886行&#xff0c;将“contentType: "application/x-w…

高性能分布式缓存Redis-第三篇章

高性能分布式缓存Redis-第三篇章一、分布式锁1.1、高并发下单超卖问题1.2、何为分布式锁1.3、分布式锁特点1.4、基于Redis实现分布式锁1.4.1、实现思路&#xff1a;1.4.2、实现代码版本1.4.3、错误解锁问题解决1.4.4、锁续期/锁续命1.4.5、锁的可重入/阻塞锁&#xff08;rediss…

微服务 Spring Boot 整合 Redis BitMap 实现 签到与统计

文章目录⛄引言一、Redis BitMap 基本用法⛅BitMap 基本语法、指令⚡使用 BitMap 完成功能实现二、SpringBoot 整合 Redis 实现签到 功能☁️需求介绍⚡核心源码三、SpringBoot 整合Redis 实现 签到统计功能四、关于使用bitmap来解决缓存穿透的方案⛵小结⛄引言 本文参考黑马 …

【第24天】SQL进阶-查询优化- performance_schema系列实战一:利用等待事件排查MySQL性能问题(SQL 小虚竹)

回城传送–》《32天SQL筑基》 文章目录零、前言一、背景二、performance_schema配置配置表启用等待事件的采集与记录三、sysbench基准测试工具3.1 安装和使用sysbench3.1.1 yum安装3.1.2 查看版本信息3.1.3 sysbench 使用说明3.2 sysbench 测试服务器cpu性能3.3 sysbench测试硬…

Hadoop 入门基础 及HiveQL

一、hadoop 解决了什么问题&#xff1f;即hadoop 产生背景 一个能够轻松方便、经济实惠地存储和分析大量数据的非常流行的开源项目。 二、hadoop 是如何低成本地解决大数据的存储和分析的&#xff1f;即hadoop 原理&#xff0c;hadoop 的组成部分 Hadoop的创始人、Cloudera首…

Java图形化界面---基本组件

目录 一、基本组件介绍 二、Diaolg对话框 &#xff08;1&#xff09;Dialog &#xff08;2) FileDialog 一、基本组件介绍 Button 按钮 Canvas 用于绘图的画布 Checkbox 复选框组件 CheckboxGroup 用于将多个…

【阶段三】Python机器学习06篇:模型评估函数介绍(分类模型)

本篇的思维导图: 模型评估函数介绍(分类模型) accuracy_score()函数 作用:accuracy_score函数计算了模型准确率。在二分类或者多分类中,预测得到的标签,跟真实标签比较,计算准确率。 注意事项:在正负样本不平衡的情况下,准确率这个评价指标有很大的缺陷。比如数据样本…

数据库管理-第五十一期 新年新气象(20230108)

数据库管理 2023-01-08第五十一期 新年新气象1 新年快乐2 旧账3 软硬件对比4 新气象总结第五十一期 新年新气象 1 新年快乐 2023年来了&#xff0c;我也没有第一时间写一篇写文章给大家祝福&#xff0c;第一呢是因为某些原因元旦假期也没咋休息&#xff0c;其次就是因为本周又…