基于分步傅立叶数值算法的一维非线性薛定谔方程求解matlab仿真

目录

1.程序功能描述

2.测试软件版本以及运行结果展示

3.核心程序

4.本算法原理

5.完整程序


1.程序功能描述

基于分步傅立叶数值算法的一维非线性薛定谔方程求解matlab仿真.

2.测试软件版本以及运行结果展示

MATLAB2022A版本运行

3.核心程序

复制代码
....................................................................                   
%ssfm步长
d      = 0.001;                      
M      = S/d; 
%输入脉冲
T0     = 70*tao;   
a0     = 0.12;
%高斯脉冲
U      = a0*exp(-(t/T0).^2/2);            
U0     = U;
P0     = 1.77e7;
for m=1:1:M
    U = exp(d*r*P0*i*(abs(U).*abs(U))).*U;
    %对考虑了非线性后得到的结果进行fft变换
    U = fftshift(fft(U));
    %对上面的结果在频域内进行色散计算
    U = exp(d*(i*B2*w2/2)).*U;
    %再将结果转换到时域内
    U = ifft(ifftshift(U));
end
hold on;
plot(1e2*t,abs(U),'k-.');
grid on;
xlabel('\xi');
ylabel('a');
legend('n_0=0.1*n_c','n_0=0.3*n_c','n_0=0.4*n_c');
16_025m

4.本算法原理

分步傅立叶法是一种有效且广泛应用于求解 NLSE 的数值方法,它将非线性和扩散部分分开处理,利用傅立叶变换高效地求解线性部分。其基本思想是将时间演化分成小的时间步长Δt,并在每个时间步内,先线性地处理波动项(即施加傅立叶变换处理扩散),然后处理非线性项。具体步骤如下:

本课题的方程为:

从对比可知,这两个式子形式上是相同的,区别在于本课题的式子在标准式子基础上增加了系数。

一般情况下,常规的有有限差分法和分步傅立叶法,本文我们所使用的是分布傅立叶法,下面讲一下主要的步骤:

首先,上面的公式做如下的逐步转化:

另外,从上面的式子可以看到,整个方程中U只和Z和T相关,其余均为常系数,或者是变常系数,但这U无关,那么我们简化上面的公式,把我们的公式变为标准非线性薛定谔的表现形式。

5.完整程序

VVV

相关推荐
2zcode4 小时前
基于MATLAB元胞自动机(CA)的AZ80A镁合金动态再结晶(DRX)过程模拟
开发语言·matlab·动态再结晶
jiushiapwojdap6 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
MATLAB代码顾问8 小时前
改进遗传算法(IGA)求解作业车间调度问题(JSSP)——附MATLAB代码
开发语言·matlab
米饭不加菜8 小时前
机器人矩阵运算MATLAB计算
matlab·矩阵·机器人
机器学习之心9 小时前
多智能体遗传算法(MAGA)优化最优投影方向的投影寻踪聚类评价,MATLAB代码
matlab·聚类·投影寻踪聚类评价
MATLAB代码顾问9 小时前
多种群协同进化算法(MPCE)求解大规模作业车间调度问题——附MATLAB代码
开发语言·算法·matlab
Evand J10 小时前
【MATLAB绘图教程】空间误差场图的概念及其应用,附代码
matlab·平面·绘图·定位
alphageek810 小时前
Matlab linspace函数完全指南:从基础用法到进阶技巧
开发语言·其他·matlab
xrgs_shz11 小时前
MATLAB 纹理特征提取:一文读懂 graycomatrix 与 graycoprops
人工智能·计算机视觉·matlab
2zcode13 小时前
基于MATLAB的深度学习工业表面缺陷多分类检测系统设计与实现(GUI界面+数据集+训练代码)
深度学习·matlab·分类