![60992e497a582a356db7d7e6b7da17a2.png](https://i-blog.csdnimg.cn/blog_migrate/4994f6c8af907b3dece47bf5790d47e8.jpeg)
0 前言
实现声波方程的数值模拟,常见的方法包括有限差分法(Finite Difference Method-FDM)、伪谱法(Pseudo-spectral Method-PSM)、有限单元法(Finite Element Method-FEM),我们前面已经通过有限差分法求解了声波方程,可参照以下链接:
坦荡的小平胸:有限差分法(FDM)实现声波方程数值模拟zhuanlan.zhihu.com![69d880e9c3f6389a17e257d69668168b.png](https://i-blog.csdnimg.cn/blog_migrate/1f9376d361813bf3dab1bae1370083d8.jpeg)
在这一篇文章中,我将为大家介绍如何使用伪谱法实现声波方程数值模拟。
1 模型建立
同样的,首先引入我们需要求解的声波方程表达式:
![73b69cfab549593494412916e92899ff.png](https://i-blog.csdnimg.cn/blog_migrate/c84b1f7dbeb862f17d726c53073ea249.png)
我们就先不使用非均匀介质模拟,假设介质是均匀且各向同性的(homogenous and isotropic),即波的传播速度
1.1 伪谱法求解原理及实现
伪谱法的求解本质上是利用了傅里叶变换来帮助我们求解偏微分方程,将含有偏导数的项转化为傅里叶正反变换。对于方程(1)中的未知量
![4a1455922afe15b2e436f71ffda86a35.png](https://i-blog.csdnimg.cn/blog_migrate/8690599d18046bcfdf025b998c77e78f.png)
上式中,如果我们对
![fd74cea5054e0815571adaec9e322b2a.png](https://i-blog.csdnimg.cn/blog_migrate/6f48dc989c2774f206fe964c80a740fc.png)
可以发现,通过傅里叶变换,我们将原本很复杂的偏微分项转化成了一种很简洁的表达性质,对上面的公式做一次傅里叶反变换就可以得到:
![149dd2b84108347276296495c540fd59.png](https://i-blog.csdnimg.cn/blog_migrate/679b54f95732c48984e2ddd24ce00fe6.png)
显然我们利用
同样的道理,我们也能够得到