高斯光束的matlab仿真复习进程
高等光学仿真matlab第六章高功率光纤激光器版pdf

高等光学仿真matlab第六章高功率光纤激光器版pdf高功率光纤激光器是一种基于激光光源的新型发光器件,具有高功率、高光束质量、高光谱均匀度等特点,广泛应用于激光加工、激光通信、激光雷达等领域。
本文将介绍如何使用Matlab进行高等光学仿真,从而对高功率光纤激光器进行优化设计。
1.光学仿真原理光学仿真是利用计算机模拟光的传播过程,通过建立光学系统的数学模型,计算光场的传输、衍射、反射等现象,从而分析和优化系统性能。
Matlab作为一种强大的科学计算软件,提供了丰富的工具和函数,可用于光学系统的建模和仿真。
2.建立光纤激光器模型在Matlab中,可以利用光波传输法建立高功率光纤激光器的数学模型,包括光波传输方程、折射率方程、损耗方程等。
通过优化这些方程中的参数,可以设计出性能优越的光纤激光器。
3.光纤激光器的光场分析利用Matlab的光场传播函数,可以对光纤激光器的光场进行分析,包括光束的聚焦度、光谱特性、空间分布等。
通过观察这些参数的变化,可以了解光纤激光器在不同工作条件下的性能表现。
4.优化设计光纤激光器在光学仿真过程中,可以通过调节光纤激光器的结构参数、工作条件等,实现对光纤激光器性能的优化设计。
例如,通过改变激光器的长度、折射率、掺杂浓度等参数,可以提高光纤激光器的输出功率、波长稳定性等。
5.应用与展望高功率光纤激光器具有广泛的应用前景,可以应用于激光打标、激光切割、激光焊接等领域。
随着光纤激光器技术的不断进步,相信其在工业制造、医疗美容、通信等领域中将有更加广泛的应用。
综上所述,利用Matlab进行高等光学仿真,可以实现对高功率光纤激光器的精确建模和优化设计,为其在实际应用中发挥更大的作用提供了有力支持。
希望本文能够对读者在光学仿真领域的研究和应用有所启发,推动光学技术的不断发展和创新。
光纤光学matlab仿真

在MATLAB中进行光纤光学仿真可以通过数值模拟和解方程组来模拟光的传播、衍射、衰减等光学现象。
以下是一个简单的光纤光学仿真的一般步骤:
1. 建立光纤模型:
首先,确定光纤的基本参数,例如折射率、直径、长度等。
这些参数将决定光在光纤中的传播特性。
2. 定义入射光源:
在仿真中,定义光源的参数,例如波长、功率、入射角等。
这可以通过定义入射光的波函数来实现。
3. 求解传播方程:
光在光纤中的传播可以通过解相应的偏微分方程(PDE)来模拟。
根据光的波动性质,一般可以使用薛定谔方程或亥姆霍兹方程来描述。
4. 数值求解:
使用MATLAB的数值求解工具箱,例如pdepe函数,对求解的光学方程进行数值模拟。
5. 绘制仿真结果:
使用MATLAB的绘图工具,例如plot函数,可视化仿真结果。
6. 考虑衍射和衰减:
根据光纤的特性,考虑衍射和衰减等现象,更新光学方程。
7. 优化和分析:
通过调整光纤参数,观察光的传播特性,进行性能分析和优化。
注意事项:
•要考虑光在光纤中的多模式传播,可以引入模式耦合的描述。
•对于三维传播,可以将方程扩展到三维,并使用相应的求解方法。
•使用合适的数值方法,例如有限元法、有限差分法等。
以上是一个简单的光纤光学仿真的概要步骤。
具体仿真的复杂性取决于问题的具体情况和所需的精度。
MATLAB提供了强大的工具箱,包括数值求解、绘图、优化等,可用于实现高度复杂的光学仿真。
高斯光束的matlab仿真教学内容

高斯光束的m a t l a b仿真题目:根据高斯光束数学模型,模拟仿真高斯光束在谐振腔中某一位置处的归一化强度分布并给出其二维、三维强度分布仿真图;用Matlab读取实际激光光斑照片中所记录的强度数据(读取照片中光斑的一个直径所记录的强度数据即可,Matlab读取照片数据命令为imread),用该数据画出图片中激光光斑的强度二维分布图,与之前数学模型仿真图对比。
(如同时考虑高斯光束光斑有效截面半径和等相位面特点,仿真高斯光束光强、光斑有效截面半径以及等相位面同时随传播距离z的变化并给出整体仿真图可酌情加分。
)原始光斑如图1所示,用imread命令读入matlab后直接用imshow命令读取即可,CCD采集的高斯光束光强分布图1 CCD采集的高斯光束强度分布读入的数据是一个224 X 244的矩阵,矩阵中的数值代表光强分布。
用读入的数据取中间一行(122行)画出强度分布如图2所示。
50100150200020406080100120140160180实验测量高斯曲线图2 实验测量高斯曲线用理论上的高斯曲线公式画出理论高斯曲线如图3所示。
-40-30-20-1001020304000.20.40.60.81理论高斯曲线图3 理论高斯曲线M 文件如下:A=imread('D:\documents\作业\激光原理与应用\高斯.bmp');A1=A(:,122);x1=1:1:224;x2=-100:1:100;a2=exp(-x2.^2/10);figureimshow(A);axis offtitle('\fontsize{12}CCD 采集的高斯光束光强分布');figureplot(x2,a2,'linewidth',1,'color','b');axis([-40 40 0 1.2])title('\fontsize{12}实验测量高斯曲线')figureplot(x1,A1,'linewidth',1,'color','r')title('\fontsize{12}理论高斯曲线')axis([50 200 0 180])画三维强度分布。
matlab中的高斯滤波 -回复

matlab中的高斯滤波-回复Matlab中的高斯滤波引言:数字图像处理是一门研究如何通过计算机对数字图像进行处理的学科。
在数字图像处理中,滤波是一种常见的技术,可以用于增强图像的质量、去除图像中的噪声、边缘检测等。
高斯滤波是一种常用的线性平滑滤波器之一,它能够有效地消除图像中的高频噪声,模糊图像并保留图像的边缘信息。
本文将详细介绍Matlab中的高斯滤波技术,并提供一步一步的解释和示例代码,帮助读者更好地理解和应用高斯滤波。
第一部分:理论介绍高斯滤波是一种基于高斯函数的滤波技术,其目标是对图像进行平滑处理,以减少噪声和细节信息。
高斯函数是一种钟形曲线,它具有以下特点:1. 对称性:函数在均值处对称,即高斯函数的左右两侧是完全对称的;2. 单峰性:函数只有一个峰值点,均值等于峰值点的位置;3. 零均值:函数的均值为0;4. 正定性:函数的值始终大于等于0。
在高斯滤波中,我们通过应用高斯函数的离散近似来模糊图像。
该函数的离散近似是一个离散的高斯核,用于表示在图像的每个像素点周围的权重。
第二部分:Matlab中的高斯滤波函数Matlab是一种强大的数值计算和科学计算环境,它提供了许多内置的函数和工具箱,可以轻松实现高斯滤波。
其中,"imgaussfilt"是Matlab中用于执行高斯滤波的函数之一。
该函数的基本语法如下:filtered_image = imgaussfilt(original_image, sigma);- "original_image"是输入图像,可以是灰度图像或彩色图像;- "sigma"是高斯核的标准差,用于控制滤波器的模糊程度。
较小的标准差会产生较强的模糊效果,较大的标准差会产生较弱的模糊效果。
此外,还可以使用其他可选参数来调整滤波器的行为:- "FilterSize":指定高斯核的大小,默认为3。
(完整word版)MATLAB环境下的正弦信号及高斯白噪声仿真程序说明

MATLAB 环境下的正弦信号及高斯白噪声仿真程序说明一、信号的产生及时域观察1、设定正选信号的频率为10HZ ,抽样频率为100HZ ;2、设定N(0,0.25)高斯白噪声,及噪声功率为0.25W ;3、最后将噪声叠加到正弦信号上,观察其三者时域波形。
二、信号频谱及白噪声功率谱的求解与观察1、对原正弦信号直接进行FFT ,得出其频谱;2、求白噪声的自相关函数,随机序列自相关函数的无偏估计公式为:1^01()()()N m xx n r m x n x n m N m --==+-∑ 01m N ≤≤- ^^()()xx xx r m r m =- 01m N <<-对所求自相关函数进行FFT 变换,求的白噪声的功率谱函数。
源程序:1.产生正弦信号fs=100;fc=10;x=(0:1/fs:2);n=201;y1=sin(2*pi*fc*x); %原正弦信号,频率为10a=0;b=0.5; %均值为a ,方差为b^2subplot(2,2,1);plot(x,y1,'r');title('y=sin(20pi*x)');ylabel('y');xlabel('x/20pi');grid;2.产生高斯白噪声y2=a+b*randn(1,n); %高斯白噪声subplot(2,2,2);plot(x,y2,'r');title('N(0,0.25)的高斯白噪声');ylabel('y');xlabel('x/20pi');grid;3.复合信号y=y1+y2; %加入噪声之后的信号subplot(2,2,3);plot(x,y,'r');title('混合信号');ylabel('y');xlabel('x/20pi');grid;4.复合信号功率谱密度%求复合信号的自相关函数m=50;i=-0.49:1/fs:0.49;for j=1:mR(j)=sum(y(1:n-j-1).*y(j:199),2)/(n-j);%无偏自相关函数的估计Rx(49+j)=R(j);Rx(51-j)=R(j);endFy2=fft(Rx); %傅里叶变换得出复合信号功率谱函数Fy21=fftshift(Fy2); %功率谱校正f=(0:98)*fs/99-fs/2;subplot(2,2,4);plot(f,abs(Fy21),'r');axis([-50 50 -0.5 1]);title('复合信号功率谱函数图');ylabel('F(Rx)');xlabel('w');grid;。
高斯-赛德尔迭代法matlab程序

高斯-赛德尔迭代法m a t l a b程序-CAL-FENGHAI-(2020YEAR-YICAI)_JINGBIANdisp('划分为M*M个正方形')M=5 %每行的方格数,改变M可以方便地改变剖分的点数u=zeros(M+1);%得到一个(M+1)*(M+1)的矩阵disp('对每个剖分点赋初值,因为迭代次数很高,所以如何赋初值并不重要,故采用对列线性赋值。
')disp('对边界内的点赋初值并使用边界条件对边界赋值:')for j=1:M-1for i=1:M-1u(i+1,j+1)=100*sin(pi/M*j)/M*(M-i);%对矩阵(即每个刨分点)赋初值endendfor i=1:M+1u(1,i)=100*sin(pi*(i-1)/M);%使用边界条件对边界赋值u(1,M+1)=0;endutic %获取运行时间的起点disp('迭代次数为N')N=6 %迭代次数,改变N可以方便地改变迭代次数disp('n为当前迭代次数,u为当前值,结果如下:')for n=1:Nfor p=2:Mi=M+2-p;for j=2:Mu(i,j)=*(u(i,j-1)+u(i+1,j)+u(i-1,j)+u(i,j+1));%赛德尔迭代法endendn %输出nu %输出uenddisp('所用的时间:')t=toc %获取算法运行需要的时间[x,y]=meshgrid(0:1/M:1,0:1/M:1);z=u(1,:);for a=2:M+1z=[z;u(a,:)];%获取最终迭代的结果,幅值给z,z的值代表该点的点位值endmesh(x,y,z)%绘制三维视图以便清楚地显示结果mesh(x,y,z,'FaceColor','white','EdgeColor','black') %绘制三维视图以便清楚地显示结果。
matlab仿真光束的传输特性综述

一、课程设计题目:用matlab 仿真光束的传输特性。
二、任务和要求用matlab 仿真光束通过光学元件的变换。
① 设透镜材料为k9玻璃,对1064nm 波长的折射率为1.5062,镜片中心厚度为3mm ,凸面曲率半径,设为100mm ,初始光线距离透镜平面20mm 。
用matlab 仿真近轴光线(至少10条)经过平凸透镜的焦距,与理论焦距值进行对比,得出误差大小。
② 已知透镜的结构参数为101=r ,0.11=n ,51=d ,5163.121=='n n (K9玻璃),502-=r ,0.12='n ,物点A 距第一面顶点的距离为100,由A 点计算三条沿光轴夹角分别为10、20、30的光线的成像。
试用Matlab 对以上三条光线光路和近轴光线光路进行仿真,并得出实际光线的球差大小。
③ 设半径为1mm 的平面波经凸面曲率半径为25mm ,中心厚度3mm 的平凸透镜。
用matlab 仿真平面波在透镜几何焦平面上的聚焦光斑强度分布,计算光斑半径。
并与理论光斑半径值进行对比,得出误差大小。
(方法:采用波动理论,利用基尔霍夫—菲涅尔衍射积分公式。
)2、用MATLAB 仿真平行光束的衍射强度分布图样。
(夫朗和费矩形孔衍射、夫朗和费圆孔衍射、夫朗和费单缝和多缝衍射。
)3、用MATLAB仿真厄米—高斯光束在真空中的传输过程。
(包括三维强度分布和平面的灰度图。
)4、(补充题)查找文献,掌握各类空心光束的表达式,采用费更斯-菲涅尔原理推导各类空心光束在真空中传输的光强表达式。
用matlab 对不同传输距离处的光强进行仿真。
三、理论推导部分将坐标原点选在透镜中心处,θ1=arcsin(y1/r),由n1*sinθ1=n2*sinθ2可得出θ2=arcsin(n1/n2)*(y1/r),由几何关系可得到θ=θ2-θ1,则出射光线的斜率k=tan(θ2-θ1),当入射直线y=y1时,x1=d-(r-(yr ),并设出射直线为y=k*x+b;由直线经过(x1,y1)即可求2^)2^1出b值,从而就可以求出射直线。
MATLAB 高斯光束传播轨迹的模拟

B1:xx光束传播轨迹的模拟设计任务:作图表示xx光束的传播轨迹(1)基模高斯光束在自由空间的传播轨迹;(2)基模高斯光束经单透镜变换前后的传播轨迹;(3)基模高斯光束经调焦望远镜变换前后的传播轨迹。
function vargout = B1(vargin)% B1 M-file forB1.fig%B1, by itself, creates a new B1 or raises the existing%singleton*.%%H = B1 returns the handle to a new B1 or the handle to%the existing singleton*.%%B1('CALLBACK',hObject,eventData,handles,...) calls the local%function named CALLBACK inB1.M with the given input arguments.%%B1('Property','Value',...) creates a new B1 or raises the%existing singleton*.Starting from the left, property value pairs are%applied to the GUI before B1_OpeningFunction gets called.An%unrecognized property name or invalid value makes property applicationGUIDE, GUIDATA, GUIHANDLES% Copyright 2002-2003 The MathWorks, Inc.% Edit the above text to modify the response to help B1% Last Modified by GUIDE v2.5 21-Oct-2010 17:52:32% Begin initialization code - DO NOT EDIT gui_Singleton = 1;gui_State = struct('gui_Name',mfilename, ... 'gui_Singleton',gui_Singleton, ...'gui_Callback',[]);if nargin && ischar(vargin{1})gui_State.gui_Callback = str2func(vargin{1}); endif nargout});else});end% End initialization code - DO NOT EDIT% --- Executes just before B1 is made visible. % hObjecthandle to figure% eventdatareserved - to be defined in a future version of MATLAB % handlesstructure with handles and user data (see GUIDATA)handles.output = hObject;% Update handles structureguidata(hObject, handles);% UIWAIT makes B1 wait for user response (see UIRESUME)% uiwait(handles.figure1);% vargoutcell array for returning output args (see VARGOUT);% hObjecthandle to figure% eventdatareserved - to be defined in a future version of MATLAB % handlesstructure with handles and user data (see GUIDATA) vargout{1} = handles.output;% --- Executes on button press in pushbutton1.function pushbutton1_Callback(hObject, eventdata, handles)% hObjecthandle to pushbutton1 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB % handlesstructure with handles and user data (see GUIDATA) handles.W0=str2double(get(handles.editW0,'string'));handles.B=str2double(get(handles.editB,'string'));guidata(hObject,handles);Z=-100:100;W=(handles.W0*10^4)*(sqrt(1+handles.B^2*(Z*10^6).^2./(pi^2*(handles.W0*10^4)^4)));plot(Z,W,'b',Z,-W,'b');% --- Executes on button press in pushbutton2.function pushbutton2_Callback(hObject, eventdata, handles)% hObjecthandle to pushbutton2 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB % handlesstructure with handles and user data (see GUIDATA)handles.W0=str2double(get(handles.editW0,'string'));handles.B=str2double(get(handles.editB,'string'))/1000;handles.Z=str2double(get(handles.editZ,'string'))*1000;handles.f=str2double(get(handles.editf,'string'))*10;L=(handles.Z-handles.f)*handles.f^2/((handles.Z-handles.f)^2+pi^2*handles.W0^4/handles.B^2)+handles.f;T1=-handles.Z:1:handles.Z;Y1=handles.W0*sqrt(1+T1.^2*handles.B^2/(pi^2*handles.W0^4));T2=handles.Z:1:(handles.Z+2*L);W1=(handles.W0*handles.f/sqrt((handles.f-handles.Z)^2+pi^2*handles.W0^4/handles.B^2));Y2=W1*sqrt(1+(T2-handles.Z-L).^2/(pi^2*W1^4/handles.B^2));plot(T1,Y1,'b',T1,-Y1,'b',T2,Y2,'r',T2,-Y2,'r');% --- Executes on button press in pushbutton3.function pushbutton3_Callback(hObject, eventdata, handles)% hObjecthandle to pushbutton3 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)handles.W0=str2double(get(handles.editW0,'string'));handles.B=str2double(get(handles.editB,'string'))/1000;handles.f1=str2double(get(handles.editf1,'string'))*10;handles.Z=str2double(get(handles.editZ,'string'))*1000;handles.f2=str2double(get(handles.editf2,'string'))*10;L=(handles.Z-handles.f1)*handles.f1^2/((handles.Z-handles.f1)^2+pi^2*handles.W0^4/handles.B^2)+handles.f1;T1=-handles.Z:1:handles.Z;Y1=handles.W0*sqrt(1+T1.^2*handles.B^2/(pi^2*handles.W0^4));T2=handles.Z:1:(handles.Z+L+handles.f2);W1=(handles.W0*handles.f1./sqrt((handles.f1-handles.Z)^2+pi^2*handles.W0^4./handles.B^2));Y2=W1*sqrt(1+(T2-handles.Z-L).^2./(pi^2*W1^4/handles.B^2));W2=W1*sqrt(1+handles.f2^2/(pi^2*W1^4/handles.B^2));T3=(handles.Z+L+handles.f2):1:3*(handles.Z+L+handles.f2);Y3=W2;plot(T1,Y1,'b',T1,-Y1,'b',T2,Y2,'r',T2,-Y2,'r',T3,Y3,'g',T3,-Y3,'g');grid on;function editW0_Callback(hObject, eventdata, handles)% hObjecthandle to editW0 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editW0 as text%str2double(get(hObject,'String')) returns contents of editW0 as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editW0 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); endfunction editB_Callback(hObject, eventdata, handles)% hObjecthandle to editB (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editB as text%str2double(get(hObject,'String')) returns contents of editB as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editB (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));endfunction editZ_Callback(hObject, eventdata, handles)% hObjecthandle to editZ (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editZ as text%str2double(get(hObject,'String')) returns contents of editZ as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editZ (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); endfunction editf_Callback(hObject, eventdata, handles)% hObjecthandle to editf (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editf as text%str2double(get(hObject,'String')) returns contents of editf as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editf (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); endfunction editf1_Callback(hObject, eventdata, handles)% hObjecthandle to editf1 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editf1 as text%str2double(get(hObject,'String')) returns contents of editf1 as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editf1 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); endfunction editf2_Callback(hObject, eventdata, handles)% hObjecthandle to editf2 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% Hints:get(hObject,'String') returns contents of editf2 as text%str2double(get(hObject,'String')) returns contents of editf2 as a double % --- Executes during object creation, after setting all properties.% hObjecthandle to editf2 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% Hint:edit controls usually have a white background on Windows.%See ISPC and COMPUTER.if ispcset(hObject,'BackgroundColor','white');elseset(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); end% --- Executes on mouse press over axes background.% hObjecthandle to axes1 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton4.function pushbutton4_Callback(hObject, eventdata, handles)close(gcf)% hObjecthandle to pushbutton4 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)% --- Executes on key press over pushbutton4 with no controls selected. % hObjecthandle to pushbutton4 (see GCBO)% eventdatareserved - to be defined in a future version of MATLAB% handlesstructure with handles and user data (see GUIDATA)。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
高斯光束的m a t l a b仿真题目:根据高斯光束数学模型,模拟仿真高斯光束在谐振腔中某一位置处的归一化强度分布并给出其二维、三维强度分布仿真图;用Matlab读取实际激光光斑照片中所记录的强度数据(读取照片中光斑的一个直径所记录的强度数据即可,Matlab读取照片数据命令为imread),用该数据画出图片中激光光斑的强度二维分布图,与之前数学模型仿真图对比。
(如同时考虑高斯光束光斑有效截面半径和等相位面特点,仿真高斯光束光强、光斑有效截面半径以及等相位面同时随传播距离z的变化并给出整体仿真图可酌情加分。
)原始光斑如图1所示,用imread命令读入matlab后直接用imshow命令读取即可,CCD采集的高斯光束光强分布图1 CCD采集的高斯光束强度分布读入的数据是一个224 X 244的矩阵,矩阵中的数值代表光强分布。
用读入的数据取中间一行(122行)画出强度分布如图2所示。
图2 实验测量高斯曲线用理论上的高斯曲线公式画出理论高斯曲线如图3所示。
图3 理论高斯曲线50100150200020406080100120140160180实验测量高斯曲线-40-30-20-1001020304000.20.40.60.81理论高斯曲线M文件如下:A=imread('D:\documents\作业\激光原理与应用\高斯.bmp');A1=A(:,122);x1=1:1:224;x2=-100:1:100;a2=exp(-x2.^2/10);figureimshow(A);axis offtitle('\fontsize{12}CCD采集的高斯光束光强分布');figureplot(x2,a2,'linewidth',1,'color','b');axis([-40 40 0 1.2])title('\fontsize{12}实验测量高斯曲线')figureplot(x1,A1,'linewidth',1,'color','r')title('\fontsize{12}理论高斯曲线')axis([50 200 0 180])画三维强度分布。
取图片矩阵的中间层,用mesh命令画出三维图如图4所示。
图4 三维强度分布由于读入的图片有一行白边,需要手动去除掉,否则三维图会有一边整体竖起来,影响观察。
最终的M文件如下。
A=imread('D:\documents\作业\激光原理与应用\高斯.bmp');[high, width, color] = size(A);x=1:width;y=1:high-1;mesh(x', y', double(A(2:224,:,1)));grid onxlabel('x'),ylabel('y'),zlabel('z');title('三维强度分布');再用matlab仿真理论上传播过程中高斯光束的变化这次先给出M文件:%Gaussian_propagation.m%Simulation of diffraction of Gaussian Beamclear;%Gaussian Beam%N:sampling numberN=input('Number of samples(enter from 100 to 500)=');L=10*10^-3;Ld=input('wavelength of light in [micrometers]=');Ld=Ld*10^-6;ko=(2*pi)/Ld;wo=input('Waist of Gaussian Beam in [mm]=');wo=wo*10^-3;z_ray=(ko*wo^2)/2*10^3;sprintf('Rayleigh range is %f [mm]',z_ray)z_ray=z_ray*10^-3;z=input('Propagation length (z) in [mm]');z=z*10^-3;%dx:step sizedx=L/N;for n=1:N+1for m=1:N+1%Space axisx(m)=(m-1)*dx-L/2;y(n)=(n-1)*dx-L/2;%Gaussian Beam in space domainGau(n,m)=exp(-(x(m)^2+y(n)^2)/(wo^2));%Frequency axis Kx(m)=(2*pi*(m-1))/(N*dx)-((2*pi*(N))/(N*dx))/2;Ky(n)=(2*pi*(n-1))/(N*dx)-((2*pi*(N))/(N*dx))/2;%Free space transfer functionH(n,m)=exp(j/(2*ko)*z*(Kx(m)^2+Ky(n)^2));endend%Gaussian Beam in Frequency domainFGau=fft2(Gau);FGau=fftshift(FGau);%Propagated Gaussian beam in Frequency domainFGau_pro=FGau.*H;%Peak amplitude of the initial Gaussian beamPeak_ini=max(max(abs(Gau)));sprintf('Initial peak amplitude is %f [mm]',Peak_ini)%Propagated Gaussian beam in space domainGau_pro=ifft2(FGau_pro);Gau_pro=Gau_pro;%Peak amplitude of the propagated Gaussian beamPeak_pro=max(max(abs(Gau_pro)));sprintf('Propagated peak amplitude is %f [mm]',Peak_pro)%Calculated Beam Width[N M]=min(abs(x));Gau_pro1=Gau_pro(:,M);[N1 M1]=min(abs(abs(Gau_pro1)-abs(exp(-1)*Peak_pro)));Bw=dx*abs(M1-M)*10^3;sprintf('Beam width(numerical) is %f[mm]',Bw)%Theoretical Beam Width W=(2*z_ray)/ko*(1+(z/z_ray)^2);W=(W^0.5)*10^3;sprintf('Beam width(theoretical) is %f[mm]',W)%axis in mm scalex=x*10^3;y=y*10^3;figure(1);mesh(x,y,abs(Gau))title('Initial Gaussian Beam')xlabel('x [mm]')ylabel('y [mm]')axis([min(x) max(x) min(y) max(y) 0 1])axis squarefigure(2);mesh(x,y,abs(Gau_pro))title('propagated Gaussian Beam')xlabel('x [mm]')ylabel('y [mm]')axis([min(x) max(x) min(y) max(y) 0 1])axis square程序主要根据高斯光束的传播规律计算传播过程中任意z处的高斯光强分布。
运行结果:Number of samples(enter from 100 to 500)=500wavelength of light in [micrometers]=0.568Waist of Gaussian Beam in [mm]=1ans =Rayleigh range is 5530.972982 [mm]Propagation length (z) in [mm]100000ans =Initial peak amplitude is 1.000000 [mm]ans =Propagated peak amplitude is 0.210252 [mm]ans =Beam?width(numerical) is 1.940000[mm]ans =Beam?width(theoretical) is 18.107635[mm]>>束腰半径处的理想高斯光强分布传播1m处的理想高斯光强分布传播10m处的理想高斯光强分布传播20m处的理想高斯光强分布传播30m处的理想高斯光强分布传播50m处的理想高斯光强分布传播100m处的理想高斯光强分布而用实验测得的光斑仿真的结果是:原始光斑的光强分布0.1m处1m处1.8m处5m处10m以后,已经基本是均匀强度的光斑。