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

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

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

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

∂²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);   %空间步长dxu = 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-1for j=2:n-1u(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);   %空间步长dyu = 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-1for jj=2:n-1for kk=2:k-1u(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);endend
endfor i=1:320figure(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 == 1imwrite(I,map,'test123.gif','gif','Loopcount',inf,'DelayTime',0.03);%将图像写入图形文件elseimwrite(I,map,'test123.gif','gif','WriteMode','append','DelayTime',0.03);    end
end

运行结果如下图:


 

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

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

相关文章

面试通关秘籍:一面到终面的秘密

在当今竞争激烈的职场中,面试已经成为求职者和企业之间互相了解和选择的重要环节。面试过程常常被划分为多个阶段,包括一面(初次面试)、二面(二次面试)、三面(深入面试)以及终面&…

入门:多层感知器Multiple-Layer Perceiver, MLP

本文将简单介绍多层感知器(MLP)的基本概念、原理和应用。MLP是一种前馈人工神经网络,由多层节点组成,每层节点通过权重和偏置与下一层节点相连。MLP在许多领域都有广泛的应用,如分类、回归、自然语言处理等。 本文将分…

Windows不常见问题集

● 解决CACLS 禁止修改计算机名 管理员权限运行cmd:cacls %SystemRoot%\System32\netid.dll /grant administrators:f ● Excel 2010 AltTab組合鍵設置 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer,在該路徑建32字元DWO…

Spring Boot | Spring Boot 整合 “Servlet三大组件“ ( Servlet / Filter / Listene )

目录: Spring Boot 整合 "Servlet三大组件" :1. 使用 "组件注册" 的方式 "整合Servlet三大组件" ( 实际操作为 : 创建自定义的"三大组件"对象 结合刚创建"的自定义组件对象"来 将 XxxRegistrationBean对象 通过…

STM32H7的Cache学习和应用

STM32H7的Cache学习和应用 啥是Cache?Cache的配置配置 Non-cacheable配置 Write through,read allocate,no write allocate配置 Write back,read allocate,no write allocate配置 Write back,read allocate…

电脑端微信截图文字识别功能效率更高了

近期发现微信中的截图文字识别比QQ中的截图文字识别效率高更高,效果更好。 使用方法: 安装电脑端微信客户端:https://weixin.qq.com/(如果没有下载,可以安装一下) 默认截图组合快捷键是:ALTA (使用下来感觉不是很顺手…

【JavaSE进阶】00-基础语法(13-14章) 01-面向对象 02-数组 03-常用类 04-异常处理

13 第十三章 方法覆盖和多态(Polymorphism)★★★★★ 13.1 章节目标与知识框架 13.1.1 章节目标 理解在什么情况下我们需要进行方法覆盖?掌握在满足什么条件的时候构成方法覆盖?什么是多态,代码怎么写?向上转型和向下转型都是…

pytest常用钩子函数

1、什么叫钩子函数 在Pytest框架中,钩子函数是一种允许用户扩展或者自定义测试执行过程的机制。钩子函数允许用户在测试的不同阶段插入自定义的代码,以实现特定的行为,操作或处理。这种插入式的机制使得Pytest具有高度的灵活性和扩展性。 如…

LeetCode 143. 重排链表

解题思路 相关代码 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val val; }* ListNode(int val, ListNode next) { this.val val; this.next next; }* }*…

海康4G摄像机国标注册失败,接入国标28181视频监控平台失败的问题分析、排查、解决

目录 一、问题现象 (一)背景 (二)在平台端,设备显示在线,通道不能传到平台端 (二)直接把通道接入进来,查看是否,显示请求超时 二、问题分析 &#xff0…

56、巴利亚多利德大学、马德里卡洛斯三世研究所:EEG-Inception-多时间尺度与空间卷积巧妙交叉堆叠,终达SOTA!

本次讲解一下于2020年发表在IEEE TRANSACTIONS ON NEURAL SYSTEMS AND REHABILITATION ENGINEERING上的专门处理EEG信号的EEG-Inception模型,该模型与EEGNet、EEG-ITNet、EEGNex、EEGFBCNet等模型均是专门处理EEG的SOTA。 我看到有很多同学刚入门,不太会…

二叉树练习day.8

235.二叉搜索树的最近公共祖先 链接:. - 力扣(LeetCode) 题目描述: 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共…