计算光纤色散带来的相位移动 matlab

devtools/2024/11/20 15:24:30/

 需要注意的地方

1.以下内容纯属个人理解,很有可能不准确,请大家仅做参考

2.光速不要直接用3e8 m/s,需要用精确的2.9979....

3.光的频率无论在真空还是光纤(介质)都是不变的,是固有属性,但是波长lambda=c/f在不同的介质中是不同的。

4.光在介质的传播速度vg = c/n,其中n是介质的折射率。紧接第2条,光在介质中的波长是lamda = vg/f,而非真空中的c/f;

5.一个调制在光载波fc=193.1THz两侧的信号(DSB调制),fs=30GHz。假设信号的phase=0的条件下:

光负边带相位 phase(fc-fs)=-180;

光正边带相位 phase(fc+fs)=0;

那么我将fs=30GHz的调制信号phase=0改变为phase=30,对应的:

负边带相位 phase(fc-fs)=-180-30=-210 (wrapTo180方法后,就是150度);

正边带相位 phase(fc+fs)=0+30=30;

原因在于:相对于光载波fc,正边带的角频率(ws(t))是正的(顺时针旋转),负边带的角频率是负的(-ws(t))(逆时针旋转)

6.色散参数D以及色散带来的延时计算

(1)色散参数表示经过L长度的光纤后,目标信号的波长(比如193.2THz)与参考波长(比如193.1THz对应的波长)的波长差d_lambda(c/193.1THz   -  c/193.2 THz)造成的延时,其单位是(s/m^2)

(2)造成的延时tao = D*L*d_lamda;当然,记得考虑上光传播的物理延时:L/vg;

那么tao_all =  D*L*d_lamda + L/vg;

(3)传播常数的理解,参考另一位博主的文章:全网首篇用人话讲清楚:光纤中的色散_光纤色散-CSDN博客

注意,波数k就是传播常数,当然波数不要理解为波的数量(比如有几束波)

以下是以下总结:

(4)例子(注意,此处的色散计算没有用到传播常数,而是在已经知道光参考频率Fref以及在参考频率Fref上的色散参数D做的例子):

下列公式表示了一个DSB调制的光信号(MZM直流偏压造成的相位移动是pi/2,输入角频率为ws的信号在MZM上下RF口相位差为pi),fai_0和fai_+1,fai_-1分别是色散引入的相位移动,边带信号ws的相位被默认为0度:

PD后的信号如下

所以,只需要计算fai_-1和fai_+1的大小,就能得到PD后信号的相位

%% ---- plot successful all wavelength--------------------------------------------------
c=physconst('LightSpeed'); % 真空中光速,单位:m/s
L = 10e3;  % 光纤长度,单位:m
D = 16e-6; % 色散系数,单位:s/m²
n=1.47;    % 光纤折射率
vg = c/n;  %光纤群速度
Fref  = 193.1e12; % 中心频率(光纤参考频率),单位:Hz
freq_opt = linspace(193.1e12, 195.5e12, 25)';  %频率范围193.1-195.5(THz)
Fsig_l = 30e9;  % 左边带频率 (模拟VPI由于采样不为整数的情况)
Fsig_r = 30e9;  % 右边带频率 (模拟VPI由于采样不为整数的情况)
tao_left =    zeros(length(freq_opt),1);    %存放-30°延时
tao_right =   zeros(length(freq_opt),1);   %存放+30°延时
phase_left =  zeros(length(freq_opt),1);  %存放-30°相位
phase_right = zeros(length(freq_opt),1); %存放+30°相位
phase_left_plot  = zeros(length(freq_opt),1);  %绘图
phase_right_plot = zeros(length(freq_opt),1);  %绘图
phase_true_plot = zeros(length(freq_opt),1);   %绘图
phase_PD = zeros(length(freq_opt),1);          %存放PD后信号的相位
phase_PD_wrap180 = zeros(length(freq_opt),1);  %存放PD后信号的相位(180°wrap)
for i=1:length(freq_opt)delta_lamda_l = -(c/(freq_opt(i)-Fsig_l)-c/Fref); %左边带与参考波长193.1THz的波长差(nm)delta_lamda_r =  (c/(freq_opt(i)+Fsig_r)-c/Fref); %右边带与参考波长193.1THz的波长差(nm)tao_left(i)  = D*L*delta_lamda_l + L/vg;          %左边带与参考波长193.1THz的延时差(s)tao_right(i) = D*L*delta_lamda_r + L/vg;          %右边带与参考波长193.1THz的延时差(s)phase_left(i)  = -2*pi*Fsig_l*(tao_left(i));   %左边带色散造成的相位移动(rad)phase_right(i) = -2*pi*Fsig_r*(tao_right(i));  %右边带色散造成的相位移动(rad)phase_left_plot(i)  = getDegree(-2*pi*Fsig_l*(D*L*delta_lamda_l+L/vg)) ;  %左边带色散造成的相位移动(rad)phase_right_plot(i) = getDegree(-2*pi*Fsig_r*(D*L*delta_lamda_r+L/vg)) ;  %右边带色散造成的相位移动(rad)phase_PD_wrap180(i) = (getDegree(phase_right(i))-getDegree(phase_left(i)))/2
end
phase_right_plot(1)= -phase_right_plot(1);   %因为第一个测试波长和参考波长一样,导致d_lamda为负数了
phase_true = (phase_right_plot-phase_left_plot)/2figure(1);
scatter(freq_opt,phase_left_plot,10,"o","filled");
hold on;
scatter(freq_opt,phase_right_plot,10,"^","filled");
plot(freq_opt,phase_true);
hold off;
legend("(φ+1)","(φ-1)","[(φ+1)-(φ-1)]/2");% xlim([0:196e12])  ;
% ylim([0,2.2e5]);      
set(gca,'linewidth',1.5);
set(gcf,'PaperUnits','normalized','Position',[500 200 950 450]) %采用相对值设置
% set(gca,'FontName','Times New Roman','FontSize',14);
% set(get(gca,'XLabel'),'FontName','Times New Roman','FontSize',14);
% set(get(gca,'YLabel'),'FontName','Times New Roman','FontSize',14);
set(gca,'XTick',[0:100e9:195.5e12]);
set(gca,'YTick',[-180:30:180]);
% set(get(gca, 'XLabel'), 'String', []);set(get(gca, 'YLabel'), 'String', [])% 去掉label
% set(gca,'xticklabel','','yticklabel','','zticklabel',''); % 去掉坐标值
function degree180 = getDegree(radLong)
%UNTITLED3 此处显示有关此函数的摘要
%   此处显示详细说明
tmp  = rad2deg(radLong);
degree180 = wrapTo180(tmp);
end


http://www.ppmy.cn/devtools/135511.html

相关文章

Scala 中迭代器的duplicate方法,toList方法,zip方法

duplicate方法: 复制迭代器 duplicate 返回值是一个元组,有两个数据源一样的,独立的迭代器 迭代器特点:不能回头val list8List("A","B","C")val (it8,it9)list8.iterator.duplicatewhile (it8.has…

opencv kdtree pcl kdtree 效率对比

由于项目中以一个环节需要使用kdtree ,对性能要求比较严苛&#xff0c;所以看看那个kdtree效率高一些。对比了opencv和pcl。 #include <array> #include <deque> #include <fstream> #include <opencv2/highgui.hpp> #include <opencv2/imgproc.hpp…

二本学院非科班天崩开局,如何逆天改命拿下大厂后端

天崩开局&#xff0c;如何破局自救 2021 年高考结束&#xff0c;我当时的第一志愿是计算机科学与技术专业&#xff0c;但是我被录取到了河南工程学院的高分子材料与工程专业。 我去咨询计算机相关行业的从业者&#xff0c;以及多方面网络搜集相关信息之后得到了一个很现实的消…

2024JYU计算机大赛决赛题解

U505016 退休 思路 至少需要的月数为 ⌈ 1000000 a b ⌉ \lceil\frac{1000000}{ab}\rceil ⌈ab1000000​⌉。 当月数为 k k k 时&#xff0c;可以用 ⌊ k 12 ⌋ \lfloor \frac{k}{12}\rfloor ⌊12k​⌋ 年 k % 12 k \% 12 k%12 月表示。 因为每 12 12 12 个月一年&am…

C# 文件及数据流技术

文章目录 1.文件系统操作1.1 常用文件系统类1.2 示例:文件和目录操作2.文件的读取与写入2.1 读取文件内容2.2 写入文件内容2.3 文件的读写优化3.数据流 (Stream)3.1 常用流类3.2 FileStream 示例3.3 MemoryStream 示例4.读写数据的高级技巧4.1 异步文件与流处理4.2 压缩与解压…

3、.Net UI库:CSharpSkin - 开源项目研究文章

CSharpSkin(C# 皮肤)是一个基于C#语言开发的UI框架&#xff0c;它允许开发者使用C#和.NET技术栈来创建跨平台的桌面应用程序。CSharpSkin框架通常用于实现具有自定义外观和感觉的应用程序界面&#xff0c;它提供了一套丰富的控件和组件&#xff0c;以及灵活的样式和布局系统。 …

0017__多播,IP_MULTICAST_TTL,IP_ADD_MEMBERSHIP,IP_MULTICAST_IF,IP_DROP_MEMBERSHIP

多播,IP_MULTICAST_TTL,IP_ADD_MEMBERSHIP,IP_MULTICAST_IF,IP_DROP_MEMBERSHIP_multicast membership-CSDN博客 IP_MULTICAST_LOOP - 郁郁思扬 - 博客园

IntelliJ+SpringBoot项目实战(四)--快速上手数据库开发

对于新手学习SpringBoot开发&#xff0c;可能最急迫的事情就是尽快掌握数据库的开发。目前数据库开发主要流行使用Mybatis和Mybatis Plus,不过这2个框架对于新手而言需要一定的时间掌握&#xff0c;如果快速上手数据库开发&#xff0c;可以先按照本文介绍的方式使用JdbcTemplat…