FDTD方法中的完美匹配层(PML)研究(Matlab代码实现)

 👨‍🎓个人主页:研学社的博客   

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现


💥1 概述

在FDTD方法中,我们截断了问题空间。但是在截断时,我们面临着在其边界上的反射问题。吸收边界条件(ABC)但很难在FDTD方法中制备二维ABC和使用。
这个问题由PML解决。假设一个波向外传播,它最终会到达允许空间的边缘,这是由矩阵在程序中的尺寸决定的。此概率由此 PML 解决。

📚2 运行结果

运行视频:

FDTD方法中的完美匹配层(PML)(Matlab代码实现)

https://www.bilibili.com/video/BV1sh41157rf/

 FDTD方法中的完美匹配层(PML)(Matlab代码实现)_哔哩哔哩_bilibili

部分代码:

%%%%%_______________PML(Perfectly Matched Layer)_using_FDTD__________%%%%%%%
%_________________________SOUGATA_CHATTERJEE________________________________
%%%%%%%%%_________________SAMEER_KOLKATA_CENTER___________________%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%________02/03/2011_________%%%%%%%%%%%%%
ie=60;
je=60;
ic=fix(ie/2);
jc=fix(je/2);
epsz=8.8e-12;
ddx=0.1;
dt=ddx/6e8;
%%%%%%-----Time_interval-----------%%%%%%%%%%%%
nsteps=100;
%%%%%%-----Time_interval-----------%%%%%%%%%%%%
ez=zeros(ie,je);
dz=zeros(ie,je);
hy=zeros(ie,je);
ihx=zeros(ie,je);
ihy=zeros(ie,je);
hx=zeros(ie,je);
ga=ones(ie,je);
%%%%%%-----wave_specification-----------%%%%%%%%%%%%
t0=40.0;
spread=15.0;
%------------calculated the PML parameter--------------- 

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

[1]尤双双,李孝坤.基于PML的FDTD法正演模拟[J].中国锰业,2018,36(06):191-194.DOI:10.14101/j.cnki.issn.1002-4336.2018.06.045.

[2]Sougata Chatterjee (2023). Perfectly Matched Layer(PML) in FDTD method. 

[3]李志. 基于FDTD的高阶PML算法及其在集成电路仿真中的应用[D].天津工业大学,2021.DOI:10.27357/d.cnki.gtgyu.2021.000394.

🌈4 Matlab代码实现

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CNDG-FDTD方法是一种求解电磁波问题的数值方法,其引入高斯源和PML吸收边界可以有效地模拟真实情况下的电磁波传播。下面介绍如何在Matlab实现CNDG-FDTD方法引入高斯源和PML吸收边界。 1. 高斯源的引入 在CNDG-FDTD方法,可以通过在计算区域的某个位置引入高斯源来模拟电磁波的发射和接收。假设我们要在计算区域的坐标为(x0,y0,z0)的位置引入高斯源,可以按照以下步骤进行操作: (1) 在计算区域建立一个三维数组,用于存储电磁场的值。 (2) 在坐标为(x0,y0,z0)的位置,将电磁场的初值设置为一个高斯函数,如下所示: ```matlab function E = gauss_source(x,y,z,t) E = exp(-((x-x0)^2+(y-y0)^2+(z-z0)^2)/(2*sigma^2))*sin(omega*t); end ``` 其,x、y、z分别为电磁场在各个方向上的坐标,t为时间,sigma和omega是高斯函数的两个参数,可以自行设置。 (3) 在计算过程,每个时间步长都需要更新电磁场的值。可以按照以下步骤进行操作: ```matlab for n=1:Nt % 更新电磁场的值 for i=1:Nx for j=1:Ny for k=1:Nz E(i,j,k) = E(i,j,k) + (dt/eps)*(Hx(i,j,k)-Hx(i,j-1,k)-Hy(i,j,k)+Hy(i-1,j,k)-Hz(i,j,k)+Hz(i,j,k-1)); end end end % 在高斯源处更新电磁场的值 E(x0,y0,z0) = gauss_source(x0,y0,z0,n*dt); end ``` 2. PML吸收边界的引入 PML吸收边界是一种有效的边界处理方法,可以在计算区域的边界处模拟吸收边界,从而减小边界对计算结果的影响。假设我们要在计算区域的x方向上引入PML吸收边界,可以按照以下步骤进行操作: (1) 在计算区域建立一个三维数组,用于存储电磁场的值。 (2) 在计算区域的边界处,设定一个PML吸收边界带。假设PML吸收边界的宽度为d,可以按照以下步骤进行操作: ```matlab % 在x方向上引入PML吸收边界 for i=1:d % 计算PML吸收边界处的sigma值 sigma_x = sigma_max*((i-0.5)/d)^m; % 更新PML吸收边界处的系数 kex(i) = exp(-sigma_x*dt/eps); khy(i) = exp(-sigma_x*dt/mu); % 更新PML吸收边界处的电磁场值 E(d-i+1,:,:) = kex(i)*E(d-i+2,:,:)+((kex(i)-1)/(sigma_x*dx))*Hx(d-i+1,:,:); E(Nx-d+i,:,:) = kex(i)*E(Nx-d+i-1,:,:)+((kex(i)-1)/(sigma_x*dx))*Hx(Nx-d+i,:,:); Hx(d-i+1,:,:) = khy(i)*Hx(d-i+2,:,:)+((khy(i)-1)/(sigma_x*dx))*E(d-i+1,:,:); Hx(Nx-d+i,:,:) = khy(i)*Hx(Nx-d+i-1,:,:)+((khy(i)-1)/(sigma_x*dx))*E(Nx-d+i,:,:); end ``` 其,sigma_max和m为PML吸收边界的两个参数,可以自行设置。 (3) 在计算过程,每个时间步长都需要更新电磁场的值。可以按照以下步骤进行操作: ```matlab for n=1:Nt % 更新电磁场的值 for i=1:Nx for j=1:Ny for k=1:Nz E(i,j,k) = E(i,j,k) + (dt/eps)*(Hx(i,j,k)-Hx(i,j-1,k)-Hy(i,j,k)+Hy(i-1,j,k)-Hz(i,j,k)+Hz(i,j,k-1)); end end end for i=1:Nx for j=1:Ny-1 for k=1:Nz-1 Hx(i,j,k) = Hx(i,j,k) - (dt/mu)*(E(i,j,k+1)-E(i,j,k)-E(i,j+1,k)+E(i,j,k)); Hy(i,j,k) = Hy(i,j,k) - (dt/mu)*(E(i+1,j,k)-E(i,j,k)-E(i,j,k+1)+E(i,j,k)); Hz(i,j,k) = Hz(i,j,k) - (dt/mu)*(E(i,j+1,k)-E(i,j,k)-E(i+1,j,k)+E(i,j,k)); end end end % 在PML吸收边界处更新电磁场的值 for i=1:d E(d-i+1,:,:) = kex(i)*E(d-i+2,:,:)+((kex(i)-1)/(sigma_x*dx))*Hx(d-i+1,:,:); E(Nx-d+i,:,:) = kex(i)*E(Nx-d+i-1,:,:)+((kex(i)-1)/(sigma_x*dx))*Hx(Nx-d+i,:,:); Hx(d-i+1,:,:) = khy(i)*Hx(d-i+2,:,:)+((khy(i)-1)/(sigma_x*dx))*E(d-i+1,:,:); Hx(Nx-d+i,:,:) = khy(i)*Hx(Nx-d+i-1,:,:)+((khy(i)-1)/(sigma_x*dx))*E(Nx-d+i,:,:); end end ``` 以上就是在Matlab实现CNDG-FDTD方法引入高斯源和PML吸收边界的步骤。需要注意的是,具体实现需要根据实际问题进行调整和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

荔枝科研社

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值