有限差分法求解一维、二维波动方程

差分格式方法是数值计算方法中微分以及偏微分导数的一种离散化方法。具体来说,它使用相邻两个或者多个数值点的差分来取代偏微分方程中的导数或偏导数。选择差分格式是离散化偏微分方程的第一步,通过这种离散化,我们可以将连续空间区域上的问题转化为在离散网格点上进行计算,从而更容易在计算机上实现数值求解。

差分格式方法有多种,如显式与隐式算法。显式算法相对简单,但有时为了满足计算稳定的条件,需要取很小的步长,这可能导致计算时间大大增加。而隐式格式的求解过程可以取较大的步长,虽然求解过程较为复杂,但最后一定收敛。在实际应用中,根据问题的具体特性和求解要求,可以选择合适的差分格式方法。

一维波动方程可以表示为:

∂²u/∂t² = c² * ∂²u/∂x²

其中,u 是波函数,c 是波速,t 是时间,x 是空间坐标。

为了使用中心差分格式来离散化这个方程,我们需要对时间和空间导数都使用中心差分近似。对于时间二阶导数 ∂²u/∂t²,我们可以使用以下中心差分格式:

∂²u/∂t² ≈ (u(t_{n+1}, x_i) - 2u(t_n, x_i) + u(t_{n-1}, x_i)) / dt^2

对于空间二阶导数 ∂²u/∂x²,我们使用之前提到的中心差分格式:

∂²u/∂x² ≈(u(t_n, x_{i+1}) - 2u(t_n, x_i) + u(t_n, x_{i-1})) / dx^2

将这两个差分格式代入波动方程,我们得到:

(u(t_{n+1}, x_i) - 2u(t_n, x_i) + u(t_{n-1}, x_i)) / dt^2 =c² * (u(t_n, x_{i+1}) - 2u(t_n, x_i) + u(t_n, x_{i-1})) / dx^2

整理上式,我们得到中心差分格式的有限差分方程:

u(t_{n+1}, x_i)=

2u(t_n, x_i) - u(t_{n-1}, x_i) + c² * dt^2 / dx^2 * (u(t_n, x_{i+1}) - 2u(t_n, x_i) + u(t_n, x_{i-1}))

这个方程用于更新每个内部网格点的时间下一层的值。需要注意的是,由于中心差分格式涉及到三个时间层的值(t_{n-1}, t_n, t_{n+1}),因此在时间迭代的开始,我们需要至少知道两个时间层的值(例如,通过初始条件和第一个时间步的计算)。

此外,中心差分格式通常需要满足一定的稳定性条件,这通常涉及到时间步长 dt 和空间步长 dx 的关系。对于一维波动方程,稳定性条件通常要求 dt 必须小于某个与 dx 和波速 c 相关的临界值。如果不满足稳定性条件,数值解可能会出现振荡或发散。

接着我们利用MATLAB差分方法求解下列一维波动方程:

clear all;close all;clc;

t = 2;          %时间范围,计算到2秒
x = 1;          %空间范围,0-1米
m = 320;        %时间方向分320个格子
n = 64;         %空间方向分64个格子
ht = t/(m-1);   %时间步长dt
hx = x/(n-1);   %空间步长dx

u = zeros(m,n);

%设置边界条件
i=1:n-1;
xx = i*x/(n-1);
u(1,1:n-1) = sin(2*pi*xx);
u(2,1:n-1) = sin(2*pi*xx);

%根据推导的差分公式计算
for i=2:m-1
    for j=2:n-1
        u(i+1,j) = ht^2*(u(i,j+1)+u(i,j-1)-2*u(i,j))/hx^2 + 2*u(i,j)-u(i-1,j);
    end
end

%画出数值解
[x1,t1] = meshgrid(0:hx:x,0:ht:t);
mesh(x1,t1,u)

运行结果如下图:

 MATLAB差分方法求解下列二维波动方程:

clear all;close all;clc;

t = 3;          %时间范围,计算到3秒
x = 1;y = 1;    %空间范围,0-1米
m = 320;        %时间t方向分320个格子
n = 32;         %空间x方向分32个格子
k = 32;         %空间y方向分32个格子
ht = t/(m-1);   %时间步长dt
hx = x/(n-1);   %空间步长dx
hy = y/(k-1);   %空间步长dy

u = zeros(m,n,k);

%设置边界
[x,y] = meshgrid(0:hx:1,0:hy:1);
u(1,:,:) = sin(4*pi*x)+cos(4*pi*y);
u(2,:,:) = sin(4*pi*x)+cos(4*pi*y);

%按照公式进行差分
for ii=2:m-1
    for jj=2:n-1
        for kk=2:k-1
            u(ii+1,jj,kk) = ht^2*(u(ii,jj+1,kk)+u(ii,jj-1,kk)-2*u(ii,jj,kk))/hx^2 + ...
                ht^2*(u(ii,jj,kk+1)+u(ii,jj,kk-1)-2*u(ii,jj,kk))/hy^2 + 2*u(ii,jj,kk) - u(ii-1,jj,kk);
        end
    end
end

for i=1:320
    figure(1);
    mesh(x,y,reshape(u(i,:,:),[n k]));
    axis([0 1 0 1 -4 4]);
    drawnow;
    F=getframe(gcf);%捕获坐标区或图窗作为影片帧
    I=frame2im(F);%从单个影片帧 F 返回真彩色 (RGB) 图像
    [I,map]=rgb2ind(I,256); %将 RGB 图像转换为索引图像,i索引图像,map颜色图
    if i == 1
        imwrite(I,map,'test123.gif','gif','Loopcount',inf,'DelayTime',0.03);%将图像写入图形文件
    else
        imwrite(I,map,'test123.gif','gif','WriteMode','append','DelayTime',0.03);    
    end
end

运行结果如下图:


 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【UE 委托】如何利用函数指针理解委托的基本原理

目录 0 引言1 函数指针模拟多播委托 🙋‍♂️ 作者:海码007📜 专栏:UE虚幻引擎专栏💥 标题:【UE 委托】如何利用函数指针理解委托的基本原理❣️ 寄语:书到用时方恨少,事非经过不知难…

适用于 Windows 的 10 个免费数据恢复工具集合

有时,我们都会在个人计算机上意外删除一些重要文件或数据。我们无需再担心此类问题,因为我们可以借助互联网上提供的免费数据恢复工具来恢复宝贵的数据和图像。 互联网上有许多免费的数据恢复工具,从一长串工具中,我们列出了最好…

阿里云优惠口令2024最新

2024年阿里云域名优惠口令,com域名续费优惠口令“com批量注册更享优惠”,cn域名续费优惠口令“cn注册多个价格更优”,cn域名注册优惠口令“互联网上的中国标识”,阿里云优惠口令是域名专属的优惠码,可用于域名注册、续…

【软考中级】软件设计师考点分布

文章目录 软考官网资格设置软考报考流程 【软件设计师】考点分布选择题考点分布案例题考点分布 软考官网 中国计算机技术职业资格网:https://www.ruankao.org.cn/ 官网报名平台:https://bm.ruankao.org.cn/sign/welcome 资格设置 计算机软件计算机网…

RNN知识体系构筑:详尽阐述其理论基础、技术架构及其在处理序列数据挑战中的创新应用

一、为什么需要RNN 尽管神经网络被视为一种强大且理论上能够近似任何连续函数的模型,尤其当训练数据充足时,它们能够在输入空间中的某个点( x )映射到输出空间的特定值( y ),然而,这并不能完全解释为何在众多应用场景中&#xff…

数据结构排序篇上

排序的概念及其运用 排序的概念 排序 :所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。 稳定性 :假定在待排序的记录序列中,存在多个具有相同的关键字的记录&…

震惊!借助Coze白嫖GPT4-128k解决方案

震惊!某大佬借助Coze白嫖GPT4-128k解决方案 前言 此文章介绍如何免费使用GPT-4高级模型并拓展API功能 最近的 Coze 在国内开放了,可以免费使用大模型。但是和国外的有点区别,国外版本使用的chatgpt4,国内版本使用的是语雀大模型。 Coze是一…

功能测试_订购单检查_判定表

画判定表的步骤: 列出条件 列出动作

964: 数细胞

样例: 解法: 1.遍历矩阵 2.判断矩阵[i][j],若是未标记细胞则遍历相邻所有未标记细胞并标记,且计数 实现:遍历相邻所有未标记细胞 以DFS实现: function dfs(当前状态) {if (终止条件) {}vis[标记当前状…

设计模式——外观(门面)模式10

外观模式:能为系统框架或其他复杂业务流程封装提供一个简单的接口。 例如抽奖过程中 设计模式,一定要敲代码理解 调用1(抽奖系统) /*** author ggbond* date 2024年04月08日 10:34*/ public class Lottery {public String getId…

x86处理器工作原理

对于电脑,大家可能司空见惯。但有没有想过它的处理器是如何工作的呢?下面和大家一起学习它的工作原理。 一. 最早的处理器 1.1 技术的发展 1947年,美国贝尔实验室的肖克利和同事们一起发明了晶体管。 1958年,美国人杰克基尔比发…

SpringBoot 集成H2数据库,启动执行sql, 中文乱码

目录 H2数据库介绍 SpringBoot版本:SpringBoot 2.1.12.RELEASE 快速集成H2,maven依赖 快速集成H2,数据源及关键参数配置 spring.datasource.schema参数(建表SQL脚本) spring.datasource.data参数(更新、…

napi系列学习高阶篇——通过IDE集成C/C++三方库并开发napi接口

简介 应用在调用系统固件集成的C/C三方库时,可能会由于系统固件集成端与IDE的NDK中libc版本不一致导致调用失败,而且系统固件集成的C/C三方库对于应用的调式也很不友好,需要多方编译调试,很不方便。因此本文将通过在IDE上适配ope…

16、普通数组-除自身以外的数组乘积

思路 通过辅助数组的方式 第一个从左向右的辅助数组乘积第二次从右向左的辅助数组乘积对于0<i<N-1 他的数组乘积就是左边的数组乘积*右边数组乘积然后再分类讨论i0 就是右边1-N-1的数组乘积iN-1就是左边从N-2到0的数组乘积 代码如下&#xff1a; class Solution {pub…

【MATLAB】GA_ELM神经网络时序预测算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~ 1 基本定义 GA_ELM&#xff08;Genetic Algorithm and Extreme Learning Machine&#xff09;是一种结合了遗传算法和极限学习机的神经网络时序预测算法。它的核心思想是通过使用遗传算法来优化极限学习机的权重和偏差&…

OpenCV C++学习笔记

1.图像的读取与显示 1.1 加载并显示一张图片 #include<opencv2/opencv.hpp> #include<iostream>using namespace cv; using namespace std; int main(int argc,char** argv){Mat srcimread("sonar.jpg");//读取图像if(src.empty()){printf("Could…

吴恩达深度学习 (week3,4)

文章目录 一、神经网络概述二、神经网络的表示三、神经网络的输出四、多个例子的向量化五、向量化实现的解释六、深度学习激活函数七、激活函数导数八、神经网络的梯度下降法九、深度学习随机初始化十、上述学习总结1、第一题2、第二题3、第三题4、第四题5、第五题6、第六题7、…

磁悬浮鼓风机市场规模不断增长 我国行业发展面临挑战

磁悬浮鼓风机市场规模不断增长 我国行业发展面临挑战 磁悬浮鼓风机又称磁悬浮高速离心鼓风机&#xff0c;指基于磁悬浮技术制成的气体输送设备。磁悬浮鼓风机综合性能优良&#xff0c;属于高效节能磁悬浮动力装备&#xff0c;在众多领域需求旺盛。未来随着国家节能环保政策逐渐…

将Visio绘图导出PDF文件,使其自适应大小,并去掉导入Latex的边框显示

问题描述 将Visio绘图导成pdf文件&#xff0c;首先在Visio绘图如下&#xff1a; 如果直接导出或者另存为pdf文件&#xff0c;则会发现pdf文件是整个页面大小&#xff0c;而不是图片大小。而且在导入latex等排版工具现实时&#xff0c;会显示边框。 问题解决 1.调整Visio中的页…

科软24炸穿了,25还能冲吗?

25考研&#xff0c;科软必然保持大热 不是吧兄弟&#xff0c;明眼人都能看出来&#xff0c;科软以后不会出现大冷的局面了&#xff0c;除非考计算机的人减少&#xff0c;因为科软简直是叠满了buff&#xff0c;首先科软的专业课是22408&#xff0c;考的是数学二&#xff0c;这就…
最新文章