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

🎯要点

Python数值和符号计算:

  1. 振动常微分方程:🎯中心差分求解器,绘制移动窗口研究长时间序列。🎯符号计算离散方程量化误差。🎯Python数值对比正向欧拉方法,反向欧拉方法,克兰克-尼科尔森方法和龙格-库塔法解。🎯数值计算振动能量数值收敛。🎯欧拉-克罗默方法求解器。🎯交错网格法求解器。🎯使用线性/二次函数和符号计算验证常微分方程。🎯线性/二次阻尼求解器和验证函数,绘制阻尼正弦函数图。🎯绘制钟摆动态自由体图模拟,创建求解器计算。🎯模拟弹性摆。
  2. 波形运动偏微分方程:🎯弹簧波形模拟:方程算式转换,制定递归算法,代码实现数值求解器,结果动画演示,二次解和敛率的验证函数。示例:创建吉他弦一维波形方程数值求解器,动画模拟弦振动波形。🎯反射边界的诺依曼条件,代码实现一维波形方程,验证函数检测结果。🎯可变波速,代码实现可变系数。🎯代码实现给定条件下,通用一维波形方程求解器。🎯差分方程正弦和余弦波分析,代码实现网格,离散傅里叶变换,计算对应频率。🎯对离散化参数进行泰勒级数展开,代码计算数值色散关系,代码计算二维数值色散关系并绘制二维数值色散误差结果图。🎯代码解二维线性波形方程,矢量化计算函数代码,高斯函数绘制波形在正方形中传播。
  3. 扩散偏微方程:🎯代码实现具有边界条件的一维扩散求解器,代码验证求解器,动画可视化正向欧拉结果。🎯实现前向欧拉算法和稳定条件下一维求解器,实现求解器矢量化函数 🎯一维扩散方程隐性方法:代码实现反向欧拉法求解器,及其矢量化函数。🎯二维和三维扩散方程求解器。🎯异质介质中的扩散离散化后:代码实现求解器,稀疏矩阵处理。🎯分段恒定介质中扩散的代码实现,绘图可视化恒定扩散系数结果。🎯实现稠密系数矩阵求解器,数值验证。🎯代码实现稀疏稀疏矩阵计算。🎯雅可比方法代码实现,解线性系统。
  4. 平流方程,非线性问题

🍇Python热方程有限差分计算示例

热方程基本上是一个偏微分方程,即:
∂ u ∂ t − α ∇ u = 0 \frac{\partial u}{\partial t}-\alpha \nabla u=0 tuαu=0
如果我们想用二维(笛卡尔)求解,我们可以这样写上面的热方程
∂ u ∂ t − α ( ∂ 2 u ∂ x + ∂ 2 u ∂ y ) = 0 \frac{\partial u}{\partial t}-\alpha\left(\frac{\partial^2 u}{\partial x}+\frac{\partial^2 u}{\partial y}\right)=0 tuα(x2u+y2u)=0
其中 u u u是我们想要知道的数量, t t t是时间变量, x x x y y y是空间变量, α \alpha α是扩散常数。所以基本上我们希望在 x x x y y y 中的任何地方以及随着时间的 t t t 找到解决方案 u u u。现在让我们简单地了解一下有限差分法。有限差分法是一种通过有限差分逼近导数来求解微分方程的数值方法。请记住导数的定义是:
f ′ ( a ) = lim ⁡ h → 0 f ( a + h ) − f ( a ) h f^{\prime}(a)=\lim _{h \rightarrow 0} \frac{f(a+h)-f(a)}{h} f(a)=h0limhf(a+h)f(a)
在有限差分法中,我们对其进行近似并去除限制。 因此,我们不使用微分和极限符号,而是使用 delta 符号,即有限差分。 请注意,这过于简单化了,因为我们必须使用泰勒级数展开,并通过假设某些项足够小来推导出它,但我们得到了该方法背后的粗略想法。
f ′ ( a ) ≈ f ( a + h ) − f ( a ) h f^{\prime}(a) \approx \frac{f(a+h)-f(a)}{h} f(a)hf(a+h)f(a)
在有限差分方法中,我们将“离散化”空间域和时间间隔 x、y 和 t。我们可以这样写
x i = i Δ x y j = j Δ y t k = k Δ t \begin{aligned} &x_i=i \Delta x\\ &y_j=j \Delta y\\ &t_k=k \Delta t \end{aligned} xi=iΔxyj=jΔytk=kΔt
正如我们所看到的, i 、 j i、j ij k k k 分别是 x 、 y x、y xy t t t 的每个差异的步骤。我们想要的是解 u u u,即
u ( x , y , t ) = u i , j k u(x, y, t)=u_{i, j}^k u(x,y,t)=ui,jk
请注意, k k k 是上标,表示 u u u 的时间步长。我们可以使用有限差分法写出上面的热方程,如下所示
u i , j k + 1 − u i , j k Δ t − α ( u i + 1 , j k − 2 u i , j k + u i − 1 , j k Δ x 2 + u i , j + 1 k − 2 u i , j k + u i , j − 1 k Δ y 2 ) = 0 \frac{u_{i, j}^{k+1}-u_{i, j}^k}{\Delta t}-\alpha\left(\frac{u_{i+1, j}^k-2 u_{i, j}^k+u_{i-1, j}^k}{\Delta x^2}+\frac{u_{i, j+1}^k-2 u_{i, j}^k+u_{i, j-1}^k}{\Delta y^2}\right)=0 Δtui,jk+1ui,jkα(Δx2ui+1,jk2ui,jk+ui1,jk+Δy2ui,j+1k2ui,jk+ui,j1k)=0
如果我们通过 Δ x = Δ y \Delta x=\Delta y Δx=Δy 排列上面的方程,我们得到最终的方程
u i , j k + 1 = γ ( u i + 1 , j k + u i − 1 , j k + u i , j + 1 k + u i , j − 1 k − 4 u i , j k ) + u i , j k u_{i, j}^{k+1}=\gamma\left(u_{i+1, j}^k+u_{i-1, j}^k+u_{i, j+1}^k+u_{i, j-1}^k-4 u_{i, j}^k\right)+u_{i, j}^k ui,jk+1=γ(ui+1,jk+ui1,jk+ui,j+1k+ui,j1k4ui,jk)+ui,jk
其中, γ = α Δ t Δ x 2 \gamma=\alpha \frac{\Delta t}{\Delta x^2} γ=αΔx2Δt

对于我们的模型,我们取 Δ x = 1 \Delta x=1 Δx=1 α = 2.0 \alpha=2.0 α=2.0。现在我们可以使用 Python 代码以数值方式解决这个问题,以查看各处的温度(用 i i i j j j 表示)和随时间变化的温度(用 k k k 表示)。我们首先导入所有必要的库,然后设置边界和初始条件。

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from matplotlib.animation import FuncAnimationplate_length = 50
max_iter_time = 1000alpha = 2.0
delta_x = 1delta_t = (delta_x ** 2)/(4 * alpha)
gamma = (alpha * delta_t) / (delta_x ** 2)u = np.empty((max_iter_time, plate_length, plate_length))u_initial = 0.0u_top = 100.0
u_left = 0.0
u_bottom = 0.0
u_right = 0.0u.fill(u_initial)u[:, (plate_length-1):, :] = u_top
u[:, :, :1] = u_left
u[:, :1, 1:] = u_bottom
u[:, :, (plate_length-1):] = u_right

我们已经设置了初始条件和边界条件,让我们根据上面推导的有限差分方法编写计算函数。

def calculate(u):for k in range(0, max_iter_time-1, 1):for i in range(1, plate_length-1, delta_x):for j in range(1, plate_length-1, delta_x):u[k + 1, i, j] = gamma * (u[k][i+1][j] + u[k][i-1][j] + u[k][i][j+1] + u[k][i][j-1] - 4*u[k][i][j]) + u[k][i][j]return u

让我们准备绘图函数,以便我们可以将解(对于每个 k)可视化为热图。我们使用Matplotlib库,它很容易使用。

参阅一:计算思维
参阅二:亚图跨际

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

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

相关文章

《无名之辈》新手攻略:抢先领取神秘礼包!

欢迎来到《无名之辈》!在这个丰富多彩的冒险世界里,你将踏上一段充满挑战与机遇的旅程。以下是针对新手玩家的详尽攻略,助你快速提升实力,成为一名优秀的冒险者。 第一步:迅速起步 当你第一次踏入《无名之辈》的世界时…

文献速递:基于SAM的医学图像分割--SAMUS:适应临床友好型和泛化的超声图像分割的Segment Anything模型

Title 题目 SAMUS: Adapting Segment Anything Model for Clinically-Friendly and Generalizable Ultrasound Image Segmentation SAMUS:适应临床友好型和泛化的超声图像分割的Segment Anything模型 01 文献速递介绍 医学图像分割是一项关键技术,用…

ubuntu卸载Anaconda

1. 删除配置的环境变量 sudo gedit ~/.bashrc # >>> conda initialize >>> # !! Contents within this block are managed by conda init !! __conda_setup"$(/work3/ai_tool/anaconda3/bin/conda shell.bash hook 2> /dev/null)" if [ $? -…

edge浏览器彻底删除用户账号

效果图 操作教程 -- 这个教程里面比较重要的是3,5,8 -- 如果不执行第8步,还是没有任何效果。 -- 教程地址 https://blog.csdn.net/qq_37579133/article/details/128777770 继续删除windows凭据 结束 -----华丽的分割线,以下是凑字数,大家不…

java工具

string format使用: String.format()的使用_string.format("%05d-CSDN博客

《无名之辈》天涯镖局攻略:高效拉镖窍门!

《无名之辈》天涯镖局开启要注意什么,在这里,每一次运镖都是一次刺激的冒险,而掌握合适的策略将让你事半功倍。以下是天涯镖局的开启攻略,助你在危机四伏的路途上赢得胜利。 ① 拉取适当级别的包子和加速卡 在天涯镖局中&#xf…

阿里云部署宝塔,设置了安全组还是打不开。

1.在安全组是开放正确的端口好。8888要开,但是不只是开放8888,举个例子,https://47.99.53.222:17677/49706cf7这个,要开放17677这个端口号。 2.安全组要挂载到实例上,从三个点的进入点击管理实例,加到对应的…

Rust 02.控制、引用、切片Slice

1.控制流 //rust通过所有权机制来管理内存,编译器在编译就会根据所有权规则对内存的使用进行 //堆和栈 //编译的时候数据的类型大小是固定的,就是分配在栈上的 //编译的时候数据类型大小不固定,就是分配堆上的 fn main() {let x: i32 1;{le…

C++多线程编程题

写在前面:最近练习C多线程,从网上其他博客找的一些小编程题。代码是自己写的,主要是个人复习用,如果有问题,欢迎在评论区讨论。 1.编写一个程序,开启3个线程,这3个线程的ID分别为A、B、C&#x…

tar (child): bzip2: Cannot exec: No such file or directory

当您在解压或压缩文件时遇到类似“tar (child): bzip2: Cannot exec: No such file or directory”的错误信息,这意味着tar命令试图调用bzip2程序来处理.bz2格式的压缩文件,但系统上没有找到这个程序。为了解决这个问题,您需要安装bzip2工具。…

图片格式转换:快速将PNG转换为JPG的步骤

在我们的日常生活中,经常会遇到需要改变图片格式的情况,有时候,我们可能需要将PNG格式的图片转换为jpg格式,以适应不同的需求和应用场景;本文将介绍哥实用的方法和工具,帮助您顺利将png图片转换为jpg格式。 压缩图网站…

C# 接口 interface

https://www.bilibili.com/video/BV1584y1B7xe/ 在C#中,接口(Interface)是一种引用类型,它定义了一组方法的契约,但不包含实现。接口允许不同的类实现相同的方法集,从而使它们可以以一致的方式被其他代码使…

面试经验分享 | 蓝队面试经验

关于蓝队面试经验 1.自我介绍能力 重要性 为什么将自我介绍能力放在第一位,实际上自我介绍才是面试中最重要的一点,因为护网面试并没有确定的题目,让面试官去提问 更多是的和面试官的一种 “交谈” ,面试的难易程度也自然就取决…

【第三方登录】Twitter

创建应用 APPID 和 相关回调配置 重新设置api key 和 api secret 设置回调和网址 还有 APP的类型 拿到ClientID 和 Client Secret 源码实现 获取Twitter 的登录地址 public function twitterUrl() {global $db,$request,$comId;require "inc/twitter_client/twitte…

Springboot整合瀚高

需要下载highgo驱动,然后将jar包打入进自己本地maven中 下载地址: highgi6.2.4 1.打开jar包所在的文件,然后在该文件夹中打开命令窗口(或者先打开命令窗口,然后cd到jar所在文件夹) install-file -Dfile:jar包名Dart…

腾讯VS网易:一场不见终局的游戏未来之战

国内游戏霸主腾讯最近赚足了眼球。 总体上看,腾讯手握“游戏社交”两大王牌,最近发布的财报十分亮眼,其2023年总营收和净利润分别同比增长10%和36%,展现了互联网巨头的强劲活力。 然而巨头亦有焦虑,增值服务营收同比…

FASTAPI系列 14-使用JSONResponse 返回JSON内容

FASTAPI系列 14-使用JSONResponse 返回JSON内容 文章目录 FASTAPI系列 14-使用JSONResponse 返回JSON内容前言一、默认返回的JSON格式二、JSONResponse 自定义返回三、自定义返回 headers 和 media_type总结 前言 当你创建一个 FastAPI 接口时,可以正常返回以下任意…

Prompt Engineering的4 种方法

此为观看视频 4 Methods of Prompt Engineering 后的笔记。 从通用模型到专用模型,fine tuning(微调)和prompt engineering(提示工程)是2种非常重要的方法。本文深入探讨了prompt engineering的4种方法。 首先&#…

23届嵌入式被裁,有什么好的就业建议?

最近看到了一个提问,原话如下: 本人23届毕业生,就业方向嵌入式软件,坐标深圳,工作3月公司裁员,目前接近12月开始找工作。 boss上投递简历,校招岗,比较有规模的好公司基本已读不回&am…

OM6626一款低功耗蓝牙芯片SOC芯片 -电子价签蓝牙芯片

OM6626是一个功耗优化的SOC芯片,它具有低能耗和专有的2.4ghz应用。它集成了一个高性能和低功耗的射频收发器与蓝牙基带和丰富的外设扩展。OM6626还集成了PMU (power management unit),提供高效的电源管理。它的目标是24ghz蓝牙低能耗系统、专有2.4ghz系统…