基于分步傅立叶数值算法的一维非线性薛定谔方程求解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

相关推荐
rit84324991 天前
MATLAB对组合巴克码抗干扰仿真的实现方案
开发语言·matlab
suoge2231 天前
六面体传热单元Matlab有限元编程:三大类边界条件(上篇)| 固定温度边界条件 | 表面热通量边界条件 | 热对流边界条件)
matlab·有限元编程·传热有限元·热传导有限元·六面体热单元·边界条件·对流换热
Evand J1 天前
【MATLAB例程,附代码下载链接】基于累积概率的三维轨迹,概率计算与定位,由轨迹匹配和滤波带来高精度位置,带测试结果演示
开发语言·算法·matlab·csdn·轨迹匹配·候选轨迹·完整代码
suoge2231 天前
六面体传热单元(热通量边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|纽曼边界条件|有限元传热分析
matlab·有限元·有限元编程·传热有限元·稳态传热·热传导有限元·热固耦合
suoge2231 天前
六面体传热单元(固定温度边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|狄利克雷边界|有限元传热分析
matlab·有限元·热传导·传热有限元·迪利克雷边界条件·有限元法·稳态传热
foundbug9991 天前
基于MATLAB的TDMP-LDPC译码器模型构建、仿真验证及定点实现
开发语言·matlab
Evand J1 天前
【MATLAB代码介绍】基于累积概率的三维轨迹匹配与定位,由轨迹匹配和卡尔曼滤波形成算法,带测试结果演示
算法·matlab·滤波·定位·导航·轨迹匹配
wuk9981 天前
梁非线性动力学方程MATLAB编程实现
前端·javascript·matlab
一个与程序bug抗争的程序员1 天前
Matlab App Designer设计人机交互界面并打包成exe——加法计算器
matlab·人机交互
kaikaile19951 天前
matlab计算流场
人工智能·算法·matlab