Matlab: ode45解微分方程——以弹簧振子模型为例

简介:

在科学和工程中,我们经常遇到描述事物变化的微分方程。这些方程可以帮助我们理解从行星运动到药物在体内的扩散等各种现象。但是,很多微分方程非常复杂,手动求解几乎不可能。这时,我们就可以使用像 ode45这样的工具来帮助我们找到解决方案。下面谈谈ode45函数的基本用法以及简单应用。

一、ode45()概念与用法

ode45 是 MATLAB 中用于求解常微分方程初值问题的函数,它采用了一种称为 “Runge-Kutta 方法” 的数值积分技术。具体来说,ode45 使用了一种称为 “Dormand-Prince” 方法的五阶龙格-库塔公式,同时还使用了一个自适应步长控制算法,以保证数值解的精度和稳定性。

ode45 的基本用法如下:

[t, y] = ode45(@odefun, tspan, y0)
  • @odefun 是一个函数句柄,表示待求解的微分方程组。这个函数接受两个参数:时间 t 和状态向量 y,并返回对应的导数值。
  • tspan 是一个包含两个元素的数组,表示求解的时间区间 [t_start, t_end]
  • y0 是一个包含微分方程组初始状态的列向量。

ode45 返回两个输出参数:

  • t 是一个列向量,包含求解过程中的时间点。
  • y 是一个大小为 (length(t), length(y0)) 的矩阵,每一行表示对应时间点 t 处的状态向量 y

二、ode45()步骤流程方法


使用 ode45 解微分方程组的步骤通常包括:

1. 定义方程:首先,需要将问题转化为一个或多个微分方程。
2. 编写函数:在 MATLAB 中,你需要编写一个函数来定义这些方程。这个函数将接受当前的状态(比如位置和速度)和时间作为输入,并返回状态的导数(比如加速度)。
3. 调用 ode45:使用 `ode45` 函数,输入你的方程函数、初始条件、时间跨度等参数。
4. 分析结果ode45 将返回一个近似的数值解,你可以用它来进行进一步的分析或绘图。

三、弹簧振子模型代码实践

有一个挂在天花板上的弹簧,下面挂着一个质量为 m 的物体。如果把这个物体拉下来一点然后放手,它会开始上下振动,这就是一个弹簧振子系统。这个系统的运动可以通过一个二阶微分方程来描述:

m\frac{d^2x}{dt^2} + kx = 0 

为了使用 ode45我们需要将这个二阶方程转换为一阶方程组。我们引入一个新的变量 v = dx/dt,表示物体的速度。那么加速度 d^2x/dt^2 就可以表示为 dv/dt。这个过程有点像状态空间方程的改写。现在我们有两个方程: 

v=\frac{dx}{dt}

a = \frac{dv}{dt} = -\frac{kx}{m}

 现在,我们可以按照以下步骤使用 ode45

1.定义方程,编写函数:

function dxdt = spring_system(t, x)m = 1;  % 质量 mk = 4;  % 弹簧常数 kdxdt = [x(2); -k/m * x(1)];  % 返回速度和加速度
end

 2.调用ode45:

% 从 t=0 到 t=10,初始位置为 1,初始速度为 0
[t, x] = ode45(@spring_system, [0, 10], [1, 0]); 

3.分析结果:

plot(t, x(:,1), 'r', 'LineWidth', 2); % 绘制位置随时间变化的图
hold on;
plot(t, x(:,2), 'b', 'LineWidth', 2); % 绘制速度随时间变化的图
xlabel('Time');
ylabel('Displacement/Velocity');
legend('Displacement', 'Velocity');

四、完整代码 

下面给出完整代码:

% 模拟参数
tspan = [0 10];  % 时间区间
x0 = [0.5; 0];  % 初始条件,假设初始位置为 0.5 m,初始速度为 0 m/s% 使用 ODE45 求解微分方程
[t, x] = ode45(@spring_system, tspan, x0);  %x中接收到的是函数返回值的原函数位移和速度% 绘图
figure;
plot(t, x(:,1), 'r', 'LineWidth', 2); % 绘制x随时间变化的图(位置)
hold on;
plot(t, x(:,2), 'b', 'LineWidth', 2); % 绘制x的导数随时间变化的图(速度)
xlabel('Time (s)');
ylabel('Displacement (m) / Velocity (m/s)');
legend('Displacement', 'Velocity');
title('Spring System Simulation');% 局部函数定义:定义微分方程系统
function dxdt = spring_system(t, x)m = 1;  % 质量 mk = 4;  % 弹簧常数 kdxdt = [x(2); -k/m * x(1)];  % 返回速度和加速度
end

 

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

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

相关文章

【iOS】frame与bounds区别

文章目录 前言framebounds两者区别size的区别总结 前言 在学习响应者链的过程中用到了frame与bounds的混用,这两个属性经常出现在我们的开发中,特别撰写一篇博客分析区别 首先,我们来看一下iOS特有的坐标系,在iOS坐标系中以左上…

【debug】如何使用pycharm对代码调试

后续会将所有debug中遇到的知识放入,建议关注收藏 本站友情链接: 基本理论专栏(当前更新好的debug所有内容都在这里) 【debug】报错解决方法(CondaHTTPError:HTTP 000 connection failed for url&#xff…

【回溯 状态压缩 深度优先】37. 解数独

本文涉及知识点 回溯 状态压缩 深度优先 LeetCode37. 解数独 编写一个程序,通过填充空格来解决数独问题。 数独的解法需 遵循如下规则: 数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只…

[C++核心编程-06]----C++类和对象之对象模型和this指针

🎩 欢迎来到技术探索的奇幻世界👨‍💻 📜 个人主页:一伦明悦-CSDN博客 ✍🏻 作者简介: C软件开发、Python机器学习爱好者 🗣️ 互动与支持:💬评论 &…

Microsoft 365 for Mac v16.84 office365全套办公软件

Microsoft 365 for Mac是一款功能丰富的办公软件套件,为Mac用户提供了丰富的功能和工具,提高了工作效率和协作能力。Microsoft 365 for Mac是一款专为Mac用户设计的订阅式办公软件套件,旨在提高生产力和效率。 Microsoft 365 for Mac v16.84正…

ubantu安装docker以及docker-compose

ubantu安装docker以及docker-compose 安装docker1、从官方存储库中安装Docker2、启动Docker服务3、验证 安装docker compose使用docker部署服务1、需要再opt文件夹下创建以下文件夹,/opt文件夹目录说明2、可将已备份对应文件夹拷至对应文件夹下3、在/opt/compose目录…

霍金《时间简史 A Brief History of Time》书后索引(A--D)

图源:Wikipedia INDEX A Abacus Absolute position Absolute time Absolute zero Acceleration Age of the universe Air resistance Albrecht, Andreas Alpha Centauri Alpher, Ralph Anthropic principle Antigravity Antiparticles Aristotle Arrows of time …

基于Vant UI的微信小程序开发(随时更新的写手)

基于Vant UI的微信小程序开发✨ (一)悬浮浮动1、效果图:只要无脑引用样式就可以了2、页面代码3、js代码4、样式代码 (二)底部跳转1、效果图:点击我要发布跳转到发布的页面2、js代码3、页面代码4、app.json代…

我觉得POC应该贴近实际

今天我看到一位老师给我一份测试数据。 这是三个国产数据库。算是分布式的。其中有两个和我比较熟悉,但是这个数据看上去并不好。看上去第一个黄色的数据库数据是这里最好的了。但是即使如此,我相信大部分做数据库的人都知道。MySQL和PostgreSQL平时拿出…

Spark Streaming笔记总结(保姆级)

万字长文警告!!! 目录 一、离线计算与流式计算 1.1 离线计算 1.1.1 离线计算的特点 1.1.2 离线计算的应用场景 1.1.3 离线计算代表技术 1.2 流式计算 1.2.1 流式计算的特点 1.2.2 流式计算的应用场景 1.2.3 流式计算的代表技术 二…

kernel32.dll丢失要如何解决?电脑kernel32.dll文件下载方法

kernel32.dll丢失要怎么解决才好?其实针对这个问题还是有很多种的解决方法的,只要你明白了kernel32.dll的作用,了解kernel32.dll,那么就可以有很多种方法去解决,下面一起来看看吧。 一.了解kernel32.dll文件 kernel32…

6个超TM好用的神仙App推荐!

1. AI文本视频生成工具——Jurilu Jurilu 是一款功能强大的 AI 文本视频生成器,允许用户快速将文本内容转换成极具吸引力的视频。它的使用非常简单:只需要输入文字,选择想要的样式和模板,Jurilu 就会自动将文字转换成生动的视频。…

Vue项目npm install certificate has expired报错解决方法

1.Vue项目 npm install 安装依赖突然报错: npm ERR! code CERT_HAS_EXPIRED npm ERR! errno CERT_HAS_EXPIRED npm ERR! request to https://registry.npm.taobao.org/zrender/download/zrender-4.3.0.tgz failed, reason: certificate has expired npm ERR! A com…

一个可以同时使用USB和WIFI传输文件到电脑的软件

双轨快传 结合USB2.0和WIFI6技术,通过1000Mbps网口实现每秒高达150MB的传输速率(理论上可达40MB/s通过USB和110MB/s通过WIFI)。 使用 模式 支持普通模式和Root模式,Root模式可访问~/Android/data/与/data/data/目录下的文件。 …

ETL-kettle数据转换及组件使用详解

目录 一、txt文本转换成excel 1、新建、转换 2、构建流程图 3、配置数据流图中的各个组件 3.1、配置文件文本输入组件 3.2、 配置Excel输出组件 4、保存执行 二、excel转换成mysql (1)在MySQL数据库中创建数据库,这个根据自身情况。我…

一文了解spring的aop知识

推荐工具 objectlog 对于重要的一些数据,我们需要记录一条记录的所有版本变化过程,做到持续追踪,为后续问题追踪提供思路。objectlog工具是一个记录单个对象属性变化的日志工具,工具采用spring切面和mybatis拦截器相关技术编写了api依赖包&a…

机器学习实战宝典:用scikit-learn打造智能应用

书接上文——《数据探险家的终极指南:用Python挖掘机器学习的奥秘》 前文我们在这段精彩的机器学习探险之旅中,从基础概念出发,深入探索了使用Python和scikit-learn库进行数据分析和模型构建的全过程。 我们首先了解了机器学习的基本原理&am…

Mysql 锁

锁 从锁的性能有乐观锁和悲观锁;锁的粒度有行锁、页锁、表锁;锁的对数据库操作类型有读锁、写锁、意向锁 乐观锁:采用cas机制,不会阻塞数据库操作,只会针对当前事务进行失败重试。(用于写操作不多的情况)悲观锁&…

[c++]多态的分析

多态详细解读 多态的概念多态的构成条件 接口继承和实现继承: 多态的原理:动态绑定和静态绑定 多继承中的虚函数表 多态的概念 -通俗的来说:当不同的对象去完成某同一行为时,会产生不同的状态。 多态的构成条件 必须通过基类的指针或者引用调用虚函数1虚…

C语言/数据结构——(链表的回文结构)

一.前言 今天在牛客网上刷到了一道链表题——链表的回文结构https://www.nowcoder.com/practice/d281619e4b3e4a60a2cc66ea32855bfa?,巧合的是它的解题思路恰好是我们一起分享过两道链表题的汇总。这两道题分别是反转链表和链表的中间节点。废话不多数&#xff0c…