Python重力弹弓流体晃动微分方程模型和交直流电阻电容电路

🎯要点

🎯计算地球大气层中热层金属坠物运动轨迹 | 🎯计算炮弹最佳弹射角度耦合微分方程 | 🎯计算电磁拉莫尔半径螺旋运动 | 🎯计算航天器重力弹弓运动力学微分方程 | 🎯计算双摆的混沌运动非线性微分方程,绘制相空图 | 🎯计算绝热和无粘流流体力学微分方程 | 🎯计算容器流体晃动自由表面简谐运动数学模型 | 🎯计算化学物质的伦纳德-琼斯势物理模型 | 🎯分析直流交流电阻电容电路

📜欧拉法 | 本文 - 用例

📜MATLAB雨刮通风空调模糊器和发电厂电力聚变器卷积神经

📜Python物理量和化学量数值计算

📜Python流感常微分方程房室数学模型

📜C++计算资本市场收益及成本分配数学方程

📜Python计算物理粒子及拉格朗日和哈密顿动力学

📜C代码快速傅里叶变换-分类和推理-常微分和偏微分方程

📜Python物理学有限差分微分求解器和动画波形传播

📜Julia评估劳动力市场经济数学模型价值策略选择

📜Python嵌入式动态用户调制解调响应式射频信号

📜Python机器人动力学和细胞酶常微分方程

📜Python | C# | MATLAB 库卡机器人微分运动学 | 欧拉-拉格朗日动力学 | 混合动力控制

📜Python | C++ | MATLAB机器人正逆向运动学动力学求解器及算法

📜Python微磁学磁倾斜和西塔规则算法

📜Python烟雾液体弹性力微分模拟 | 出租车往返速度微分计算
在这里插入图片描述
在这里插入图片描述

🍇Python欧拉法

d S ( t ) d t = F ( t , S ( t ) ) \frac{d S(t)}{d t}=F(t, S(t)) dtdS(t)=F(t,S(t)) 为显式定义的一阶常微分方程。也就是说, F F F 是一个函数,它返回给定时间和状态值的状态的导数或变化。另外,令 t t t 为区间 [ t 0 , t f ] \left[t_0, t_f\right] [t0,tf] 的数字网格,间距为 h h h。不失一般性,我们假设 t 0 = 0 t_0=0 t0=0,并且对于某个正整数 N N N t f = N h t_f=N h tf=Nh

S ( t ) S(t) S(t) t j t_j tj 附近的线性近似为
S ( t j + 1 ) = S ( t j ) + ( t j + 1 − t j ) d S ( t j ) d t S\left(t_{j+1}\right)=S\left(t_j\right)+\left(t_{j+1}-t_j\right) \frac{d S\left(t_j\right)}{d t} S(tj+1)=S(tj)+(tj+1tj)dtdS(tj)
还可以写为:
S ( t j + 1 ) = S ( t j ) + h F ( t j , S ( t j ) ) S\left(t_{j+1}\right)=S\left(t_j\right)+h F\left(t_j, S\left(t_j\right)\right) S(tj+1)=S(tj)+hF(tj,S(tj))
这个公式称为显式欧拉公式,它允许我们在给定 S ( t j ) S\left(t_j\right) S(tj) 状态的情况下计算 S ( t j + 1 ) S\left(t_{j+1}\right) S(tj+1) 状态的近似值。从给定的初始值 S 0 = S ( t 0 ) S_0=S\left(t_0\right) S0=S(t0)开始,我们可以使用这个公式对状态进行积分直到 S ( t f ) S\left(t_f\right) S(tf);这些 S ( t ) S(t) S(t) 值是微分方程解的近似值。显式欧拉公式是解决初值问题最简单、最直观的方法。在任何状态 ( t j , S ( t j ) ) \left(t_j, S\left(t_j\right)\right) (tj,S(tj)),它在该状态下使用 F F F“指向”下一个状态,然后朝该方向移动 h h h的距离。尽管有更复杂和更准确的方法来解决这些问题,但它们都具有相同的基本结构。因此,我们明确列举了使用显式欧拉公式解决初始值问题的步骤。

假设我们有一个函数 F ( t , S ( t ) ) F(t, S(t)) F(t,S(t)) 计算 d S ( t ) d t \frac{d S(t)}{d t} dtdS(t),一个数值网格 t t t,区间 [ t 0 , t f ] \left[ t_0, t_f\right] [t0,tf],初始状态值 S 0 = S ( t 0 ) S_0=S\left(t_0\right) S0=S(t0)。我们可以使用以下步骤计算 t t t 中每个 t j t_j tj S ( t j ) S\left(t_j\right) S(tj)

  • S 0 = S ( t 0 ) S_0=S\left(t_0\right) S0=S(t0) 存储在数组 S S S 中。
  • 计算 S ( t 1 ) = S 0 + h F ( t 0 , S 0 ) S\left(t_1\right)=S_0+h F\left(t_0, S_0\right) S(t1)=S0+hF(t0,S0)
  • S 1 = S ( t 1 ) S_1=S\left(t_1\right) S1=S(t1) 存储在 S S S
  • 计算 S ( t 2 ) = S 1 + h F ( t 1 , S 1 ) S\left(t_2\right)=S_1+h F\left(t_1, S_1\right) S(t2)=S1+hF(t1,S1)
  • S 2 = S ( t 1 ) S_2=S\left(t_1\right) S2=S(t1) 存储在 S S S​ 中。
  • 计算 S ( t f ) = S f − 1 + h F ( t f − 1 , S f − 1 ) S\left(t_f\right)=S_{f-1}+h F\left(t_{f-1}, S_{f-1}\right) S(tf)=Sf1+hF(tf1,Sf1)
  • S f = S ( t f ) S_f=S\left(t_f\right) Sf=S(tf) 存储在 S S S
  • S S S 是初始值问题的近似解

当使用具有这种结构的方法时,我们称该方法集成了常微分方程的解。

初始条件为 f 0 = − 1 f_0=-1 f0=1的微分方程 d f ( t ) d t = e − t \frac{d f(t)}{d t}=e^{-t} dtdf(t)=et有精确解 f ( t ) = − e − t f(t)=-e^{-t} f(t)=et 。使用显式欧拉公式,以 0.1 为增量,在 0 和 1 之间近似求解此初始值问题。绘制近似解和精确解之间的差异。

代码处理:

import numpy as np
import matplotlib.pyplot as pltplt.style.use('seaborn-poster')
%matplotlib inlinef = lambda t, s: np.exp(-t) 
h = 0.1 
t = np.arange(0, 1 + h, h) 
s0 = -1 s = np.zeros(len(t))
s[0] = s0for i in range(0, len(t) - 1):s[i + 1] = s[i] + h*f(t[i], s[i])plt.figure(figsize = (12, 8))
plt.plot(t, s, 'bo--', label='Approximate')
plt.plot(t, -np.exp(-t), 'g', label='Exact')
plt.title('Approximate and Exact Solution \
for Simple ODE')
plt.xlabel('t')
plt.ylabel('f(t)')
plt.grid()
plt.legend(loc='lower right')
plt.show()

在上图中,我们可以看到每个点都是基于前一个点以线性方式进行的近似。从初始值,我们最终可以得到数值网格上解的近似值。如果我们对 h = 0.01 h=0.01 h=0.01 重复该过程,我们会得到更好的近似解:

h = 0.01 
t = np.arange(0, 1 + h, h) 
s0 = -1 s = np.zeros(len(t))
s[0] = s0for i in range(0, len(t) - 1):s[i + 1] = s[i] + h*f(t[i], s[i])plt.figure(figsize = (12, 8))
plt.plot(t, s, 'b--', label='Approximate')
plt.plot(t, -np.exp(-t), 'g', label='Exact')
plt.title('Approximate and Exact Solution \
for Simple ODE')
plt.xlabel('t')
plt.ylabel('f(t)')
plt.grid()
plt.legend(loc='lower right')
plt.show()

显式欧拉公式之所以被称为“显式”,是因为它只需要 t j t_j tj 处的信息来计算 t j + 1 t_{j+1} tj+1 处的状态。也就是说, S ( t j + 1 ) S\left(t_{j+1}\right) S(tj+1) 可以根据我们拥有的值(即 t j t_j tj S ( t j ) S\left(t_j\right) S(tj) )显式地编写。隐式欧拉公式可以通过在 t j + 1 t_{j+1} tj+1 周围取 S ( t ) S(t) S(t) 的线性近似并在 t j t_j tj 处计算来导出:
S ( t j + 1 ) = S ( t j ) + h F ( t j + 1 , S ( t j + 1 ) ) S\left(t_{j+1}\right)=S\left(t_j\right)+h F\left(t_{j+1}, S\left(t_{j+1}\right)\right) S(tj+1)=S(tj)+hF(tj+1,S(tj+1))
这个公式很奇特,因为它要求我们知道 S ( t j + 1 ) S\left(t_{j+1}\right) S(tj+1) 才能计算 S ( t j + 1 ) S\left(t_{j+1}\right) S(tj+1)!不过,有时候我们可以用这个公式来近似求解初值问题。在详细介绍如何使用隐式欧拉公式解决这些问题之前,我们先给出另一个隐式公式,称为梯形公式,它是显式和隐式欧拉公式的平均值:
S ( t j + 1 ) = S ( t j ) + h 2 ( F ( t j , S ( t j ) ) + F ( t j + 1 , S ( t j + 1 ) ) ) S\left(t_{j+1}\right)=S\left(t_j\right)+\frac{h}{2}\left(F\left(t_j, S\left(t_j\right)\right)+F\left(t_{j+1}, S\left(t_{j+1}\right)\right)\right) S(tj+1)=S(tj)+2h(F(tj,S(tj))+F(tj+1,S(tj+1)))
为了说明如何求解这些隐式解,请再次考虑已简化为一阶的摆方程。

👉参阅一:计算思维

👉参阅二:亚图跨际

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

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

相关文章

【C++】类和对象(四)拷贝构造、赋值运算符重载

文章目录 四、拷贝构造函数干嘛的?写拷贝构造函数的注意事项正确写法 不显示定义拷贝构造函数的情况浅拷贝:one:示例:内置类型:two:示例:自定义类型一个提问 深拷贝 五、赋值运算符重载运算符重载函数原型注意调用时的两种书写方式完整实现代…

SAFEnet加密机的加密算法和技术

SAFEnet加密机是一款功能强大、安全可靠的加密设备,它在网络安全领域发挥着不可替代的作用。下面将从特点、功能、应用及优势等方面对SAFEnet加密机进行详细介绍。 一、特点 先进的加密算法和技术:SAFEnet加密机采用了最先进的加密算法和技术&#xff0c…

12 物理层解析

物理层解析 一、物理层功能 ​ 物理层主要功能 功能一:为数据端设备提供传送数据的通路 功能二:传输数据 二、物理层关心的问题 (一)信号 ​ 信息是人对现实世界事物存在方式或运动状态的某种认识 ​ 数据是用于描述事物的…

网络安全:什么是SQL注入

文章目录 网络安全:什么是SQL注入引言SQL注入简介工作原理示例代码 攻击类型为什么SQL注入危险结语 网络安全:什么是SQL注入 引言 在数字化时代,数据安全成为了企业和个人最关心的问题之一。SQL注入(SQL Injection)是…

【面试干货】Java的基础类型和字节大小

【面试干货】Java的基础类型和字节大小 💖The Begin💖点点关注,收藏不迷路💖 在Java编程语言中,有八种基本数据类型,它们分别是:布尔型(boolean)、字节型(byt…

厚膜电阻电路丝网印刷

厚膜丝网印刷 该技术用于需要长寿命、热耐久性、机械强度、导热性、高密度电气互连、低介电损耗等的苛刻应用 特征: 陶瓷标准工艺从前到后的通孔连接 正面和背面的丝网印刷电阻器是标准工艺 金导体可以用金线和/或氧化铝线进行线键合 可焊接金属化,…

oracle 数据库导入dmp文件

荆轲刺秦王 从线上正式环境导出的 dmp 文件,导入到本地 oracle 数据库。 1. 创建用户: CREATE USER hf_chip IDENTIFIED BY hf_chip; 2. 授予 CONNECT 和 RESOURCE 基本权限给新用户。 GRANT CONNECT, RESOURCE TO hf_chip; 3. 创建表空间 CREATE TABLESPACE…

【C++高阶】探索STL的瑰宝 map与set:高效数据结构的奥秘与技巧

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C “ 登神长阶 ” 🤡往期回顾🤡:初步了解 二叉搜索树 🌹🌹期待您的关注 🌹🌹 ❀map与set 📒1.…

开发uniapp插件包aar文件,使uniapp可以调用jar包

背景 使用 uniapp 开发应用时,很多时候都需要调用第三方的sdk,一般以 jar 为主。为了应对这个问题,官方提供了插件方案,可以将第三方 jar 包进行封装为 aar 包后,再集成到 uniapp 中使用。 一、环境安装工具 1、jdk…

C语言练习02-数组

一、求最值 已知数组元素为{33,5,22,44,55}&#xff0c;找出数组中的最大值并打印在控制台 #include<stdio.h> #include<math.h>int main() {int arr[] {33,5,22,44,55};int max arr[0];int len sizeof(arr) / sizeof(int); //注意&#xff1a;sizeof(arr)计算…

【无线传感网】分簇路由算法介绍

目录 1、LEACH路由算法 2、PEGASIS 算法 3、TEEN 算法 5、APTEEN 5、LEACH-C 算法 无线传感网中的路由协议就是寻找一条路径让网络中节点沿着这条路径将数据信息传输出去。路由协议的两大关键要点就是路径的优化和数据的分组,在传统计算机网络中,是将网络的拓扑…

Linux系统安装Dify结合内网穿透实现远程访问本地LLM开发平台

文章目录 前言1. Docker部署Dify2. 本地访问Dify3. Ubuntu安装Cpolar4. 配置公网地址5. 远程访问6. 固定Cpolar公网地址7. 固定地址访问 前言 本文主要介绍如何在Linux Ubuntu系统使用Docker快速部署大语言模型应用开发平台Dify,并结合cpolar内网穿透工具实现公网环境远程访问…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] API集群访问频次统计(100分) - 三语言AC题解(Python/Java/Cpp)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; &#x1f…

Python酷库之旅-第三方库openpyxl(01)

目录 一、 openpyxl库的由来 1、背景 2、起源 3、发展 4、特点 4-1、支持.xlsx格式 4-2、读写Excel文件 4-3、操作单元格 4-4、创建和修改工作表 4-5、样式设置 4-6、图表和公式 4-7、支持数字和日期格式 二、openpyxl库的优缺点 1、优点 1-1、支持现代Excel格式…

前端基础操作1——利用nvm任意切换(管理)node版本

在实际前端项目开发过程中&#xff0c;同时开发多个项目或者切换新项目时&#xff0c;因为node版本问题造成项目无法运行的问题比比皆是&#xff0c;这时候通过nvm管理切换不同版本的node&#xff0c;就能很快进入开发模式&#xff0c;避免因为环境问题浪费大量精力&#xff0c…

安卓系统安装linux搭建随手服务器termux平替软件介绍

引言 旧手机丢可惜&#xff0c;可以用ZeroTermux&#xff08;一款代替termux&#xff09;的超级终端&#xff0c;来模拟Linux&#xff08;甚至你可以模拟Win&#xff0c;只要性能够用&#xff09; ps&#xff1a;此软件只是termux的增强版&#xff0c;相当于增加右边菜单&…

校园任务平台系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;管理员管理&#xff0c;论坛管理&#xff0c;任务咨询管理&#xff0c;用户管理&#xff0c;基础数据管理 前台账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;任务资讯公告&#…

AGI的多模态融合

在人工智能的宏伟蓝图中&#xff0c;人工通用智能&#xff08;AGI&#xff09;代表着一个集大成者&#xff0c;一个能够理解、学习、适应并执行任何智能任务的系统。随着我们对AGI的探索愈发深入&#xff0c;尤其是在视觉、语言和其他模态的融合上&#xff0c;关于AGI的讨论愈发…

图像分割(三)-RGB转HSV后图像分割方法

常用彩色模型有RGB和HSV模型&#xff0c;有时候在RGB颜色空间进行背景分割比较困难的问题&#xff0c;转换为HSV模型然后对色调和饱和度图像进行处理会得到比较理想的处理结果,下面通过一个实例讲解该方法的MATLAB实现&#xff0c;该方法对其他图像检测也具有一定的参考价值。 …

React路由笔记(函数组件,自用)

配置 npm i react-router-dom基本使用 目录结构 在src中创建page文件夹放置各页面组件&#xff0c;router中放置路由 1、router中配置路由 在/router/index.js中&#xff0c;使用createBrowserRouter配置路由。 import { createBrowserRouter } from "react-router…