24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1201  |  回复: 0

lmhdzxx

新虫 (正式写手)

[求助] 用分步傅里叶法求解光纤中非线性薛定谔方程

不知这里哪位虫子有用分步傅里叶法求解光纤中非线性薛定谔方程的MATLAB程序啊?我用Agrawal那本非线性光纤光学后面的程序加以改动,但是得出的图效果不理想,有没有哪位同学有程序啊?真心求交流。。。。。
附程序:
%传输距离为1到4,其他参数不变,最后得出不同传输距离下频域光脉冲形状的比较
clear all;
for m=1:4
%---Input Field profile
distance = 10*m; %传输距离
beta2 =-1;%二阶色散参数
chirp = 0; % 初始啁啾参数
peakpower=1;%峰值功率
T0=1;%初始脉宽
r=1  ;  %非线性系数
N=sqrt(r*peakpower*T0^2) ;
alpha=1;%光纤损耗
%---set simulation parameters
nt =1024; Tmax = 10; % FFT points and window size,设置采样点和时间窗口
step_num = round(20*distance*N^2) % No. of z steps to
deltaz = distance/step_num; % step size in z
dtau = (2*Tmax)/nt; % step size in tau
%---tau and omega arrays
tau = (-nt/2:nt/2-1)*dtau; % temporal grid
omega = (pi/Tmax)*[(-nt/2:nt/2-1)]; % frequency grid
%---store dispersive phase shifts to speedup code
dispersion = exp((1i*0.5*beta2*omega.^2-alpha/2)*deltaz);% phase factor
hhz = 1i*N^2*deltaz; % nonlinear phase factor
uu =sqrt(peakpower)*exp(-0.5*tau.^2.*(1+1i*chirp)/T0^2);  % gaussian
temp = uu.*exp((abs(uu).^2).*hhz/2); % note hhz/2
subplot(2,1,1)
if m==1
      plot(fftshift(omega)/(2*pi),-log10(abs(temp).^2),'r')
      hold on
else if m==2
      plot(fftshift(omega)/(2*pi),-log10(abs(temp).^2),'y')
      hold on
     else if m==3
             plot(fftshift(omega)/(2*pi),-log10(abs(temp).^2),'b')
             hold on
         else plot(fftshift(omega)/(2*pi),-log10(abs(temp).^2),'k')
         end
     end
end
%*********[ Beginning of MAIN Loop]***********
% scheme: 1/2N -> D -> 1/2N; first half step nonlinear
for n=1:step_num
f_temp = ifft(temp).*dispersion;
uu = fft(f_temp);
temp = uu.*exp((abs(uu).^2).*hhz/2);
end
uu = temp.*exp(-(abs(uu).^2).*hhz/2);% Final field
temp = fftshift(ifft(uu)).*(nt*dtau)/sqrt(2*pi);%Final spectrum
subplot(2,1,2)
if m==1
      plot(fftshift(omega)/(2*pi),log10(abs(temp)).^2,'r')
      hold on
else if m==2
      plot(fftshift(omega)/(2*pi),log10(abs(temp)).^2,'y')
      hold on
     else if m==3
             plot(fftshift(omega)/(2*pi),log10(abs(temp)).^2,'b')
             hold on
         else plot(fftshift(omega)/(2*pi),log10(abs(temp)).^2,'k')
         end
     end
end
     
%***************[ End of MAIN Loop ]**************
%----Plot output pulse shape and spectrum
%TEMP(m,=temp;
end
%for m=1:4  plot(fftshift(omega)/(2*pi),-20*(log10(abs(TEMP(m,).^2)));
%   plot(fftshift(omega)/(2*pi),-20*(log10(abs(TEMP(m,).^2)));
%end
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

智能机器人

Robot (super robot)

我们都爱小木虫

找到一些相关的精华帖子,希望有用哦~

科研从小木虫开始,人人为我,我为人人
相关版块跳转 我要订阅楼主 lmhdzxx 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 271求调剂 +32 2261744733 2026-04-11 33/1650 2026-04-15 22:03 by noqvsozv
[考研] 273求调剂 +6 白居不易. 2026-04-09 8/400 2026-04-15 22:02 by wooluyong
[考研] 297工科调剂? +14 河南农业大学-能 2026-04-13 15/750 2026-04-15 13:25 by 黑科技矿业
[考研] 化学070300 求调剂 +23 哈哈哈^_^ 2026-04-12 23/1150 2026-04-14 16:30 by zhouxiaoyu
[考研] 279求调剂 +12 张番茄不炒蛋 2026-04-11 12/600 2026-04-14 15:38 by zs92450
[考研] 0856专硕求调剂 希望是a区院校 +24 好好休息好不好 2026-04-09 27/1350 2026-04-13 22:22 by pies112
[考研] 346分,工科0854求调剂,专硕 +6 moser233 2026-04-12 7/350 2026-04-12 22:11 by fqwang
[考研] 22408 352分求调剂 +5 努力的夏末 2026-04-09 5/250 2026-04-12 19:17 by wj165256
[考研] 2本,初试303,0860求调剂 +6 floriea 2026-04-12 8/400 2026-04-12 18:13 by zhouxiaoyu
[考研] 电气工程专硕320求调剂 +5 小麻子111 2026-04-10 5/250 2026-04-12 10:47 by zhouyuwinner
[考研] 280求调剂 +13 wzzz王 2026-04-09 13/650 2026-04-12 00:31 by 勇攀高峰0126
[考研] 22408调剂315分 +3 zhuangyan123 2026-04-09 3/150 2026-04-12 00:25 by 蓝云思雨
[考研] 331求调剂 +5 王国帅 2026-04-11 5/250 2026-04-11 22:56 by 溪涧流水
[考研] 调剂 +6 青灯不负 2026-04-09 6/300 2026-04-11 20:35 by dongdian1
[考研] 359求调剂 +5 胃痉挛累了 2026-04-11 5/250 2026-04-11 19:55 by lbsjt
[考研] 296求调剂 +6 汪!?! 2026-04-09 6/300 2026-04-11 11:25 by zhq0425
[考研] 求调剂 +6 archer.. 2026-04-09 8/400 2026-04-11 10:55 by zhq0425
[考研] 0854调剂 +5 音像店听花鼓戏 2026-04-10 5/250 2026-04-11 10:49 by qingpingzhu
[考研] 087100初试311求调剂 +4 任雅琴 2026-04-09 4/200 2026-04-11 10:33 by zhq0425
[考研] 广东省 085601 329分求调剂 +14 Eddieddd 2026-04-10 14/700 2026-04-11 09:58 by bljnqdcc
信息提示
请填处理意见