XX大学XXXX学院1工程光学综合练习-----圆孔、矩孔的菲涅尔衍射模拟XX大学XXXX学院2圆孔和矩孔的菲涅尔衍射模拟一、原理由惠更斯-菲涅尔原理可知接收屏上的P点的复振幅可以表示为𝐸̃(𝑃)=𝐶∬𝐸̃(Q)exp(𝑖𝑘𝑟)𝑟𝛴K(θ)dσ(1)其中𝐸̃(Q)为衍射屏上的复振幅分布,K(θ)为倾斜因子。根据基尔霍夫对此公式的完善,有C=1𝑖𝜆K(θ)=1+𝑐𝑜𝑠𝜃2≈1设衍射屏上点的坐标为(x1,y1),接收屏上点的坐标为(x,y),衍射屏与接收屏间距离为z1,当满足菲涅尔近似条件时,即𝑘8𝑧13[(𝑥−𝑥1)2+(𝑦−𝑦1)2]𝑚𝑎𝑥2≪𝜋(2)此时可得到菲涅尔衍射的计算公式𝐸̃(x,y)=exp(𝑖𝑘𝑧1)iλ𝑧1∬𝐸̃(𝑥1,𝑦1)∞−∞exp{𝑖𝑘2𝑧1[(𝑥−𝑥1)2+(𝑦−𝑦1)2]}𝑑𝑥1𝑑𝑦1(3)把上式指数项中的二次项展开,并改写成傅里叶变换的形式,可以写成𝐸̃(x,y)=exp(𝑖𝑘𝑧1)iλ𝑧1exp[𝑖𝑘2𝑧1(𝑥2+𝑦2)]f{𝐸̃(𝑥1,𝑦1)exp[𝑖𝑘2𝑧1(𝑥12+𝑦12)]}(4)上式为菲涅尔衍射的傅里叶变换表达式,它表明除了积分号前面的一个与x1、y1无关的振幅和相位因子外,菲涅尔衍射的复振幅分布是孔径平面的复振幅分布和一个二次相位因子乘积的傅里叶变换。相对于夫琅和费衍射而言,菲涅尔衍射的观察屏距衍射屏不太远。在菲涅尔衍射中,输入变量和输出变量分别为衍射孔径平面的光场分布和观察平面的光场以及光强分布,考虑到这三个量都是二维分布,而且Matlab主要应用于矩阵数值运算,所以本程序选择用二维矩阵来存储衍射孔径平面和观察平面的场分布,并分别以矩阵的列数和行数来对应平面的直角坐标值(x,y)以及(x1,y1)。二、圆孔菲涅尔衍射用MATLAB分别构造表示衍射屏和接收屏的二维矩阵。注意使两矩阵阶次相同,考虑到运算量的要求,采样点数不能过多,所以每个屏的x和y方向各取200到300点进行运算。根据式(4),选取合适的衍射屏和接收屏尺寸和相距XX大学XXXX学院3的距离,模拟结果如下:取典型的He-Ne激光器波长λ=632.8nm,固定衍射屏和接收屏尺寸和相距的距离,分别取不同的圆孔半径,得到以下三组衍射图样,其圆孔半径分别为12mm,20mm,50mm图1(r=12mm)图2(r=20mm)XX大学XXXX学院4图3(r=50mm)三、矩孔的菲涅尔衍射步骤与上述相同,仅需改变与衍射屏形状对应的矩阵。这里选择矩孔的长宽相等,分别为15mm,20mm,30mm,其衍射图样及强度分布如图4、5、6图4(a=b=15mm)XX大学XXXX学院5图5(a=b=20mm)图6(a=b=30mm)XX大学XXXX学院6四、MATLAB程序%所有长度单位为毫米lamda=632.8e-6;k=2*pi/lamda;z=1000000;%先确定衍射屏N=300;%圆屏采样点数a=15;b=15;[m,n]=meshgrid(linspace(-N/2,N/2-1,N));I=rect(m/(2*a)).*rect(n/(2*b));q=exp(j*k*(m.^2+n.^2)/2/z);subplot(2,2,1);%圆孔图像画在2行2列的第一个位置imagesc(I)%画衍射屏的形状colormap([000;111])%颜色以黑白区分axisimagetitle('衍射屏形状')L=300;M=300;%取相同点数用于矩阵运算[x,y]=meshgrid(linspace(-L/2,L/2,M));h=exp(j*k*z)*exp((j*k*(x.^2+y.^2))/(2*z))/(j*lamda*z);%接收屏H=fftshift(fft2(h));B=fftshift(fft2(I));%圆孔频谱G=H.*B;%公式中为卷积,空间域中相卷相当于频域中相乘U=fftshift(ifft2(G));%求逆变换,得到复振幅分布矩阵Br=(U/max(U));%归一化subplot(2,2,2);imshow(abs(U));axisimage;colormap(hot)%figure,imshow(C);title('衍射后的图样');subplot(2,2,3);mesh(x,y,abs(U));%画三维图形subplot(2,2,4);plot(abs(Br))若为圆孔,方框内替换为以下程序r=12;a=1;b=1;I=zeros(N,N);[m,n]=meshgrid(linspace(-N/2,N/2-1,N));D=((m-a).^2+(n-b).^2).^(1/2);i=find(D=r);I(i)=1;%孔半径范围内透射系数为1