本文的目的总结一些标量衍射的计算方法,并讨论讨论他们的适用条件。代码和例子在:https://github.com/sleepingcat42/Scalardiffraction
需要的预备知识:涉及的数理知识并不高深,主要是线性系统和傅里叶变换(离散傅里叶变换)的基础知识,当然还有光学。
涉及的内容:准确地说,应该是讨论基于快速傅里叶变换(FFT)的标量衍射,主要是常见的几种衍射计算方法
- 瑞利-索末菲/角谱衍射
- 菲涅尔衍射(Fres-TF 和 Fres-IR)
其他衍射计算方法(待补充)
- 单步菲涅尔衍射
- 两步菲涅尔衍射
- 夫琅禾费衍射
- 其他(未来补充)
本文的重点并不在标量衍射的推导,所以跳过麦克斯韦方程组,和参考文献[2] 类似,直接到跳到第一类瑞利-索末菲积分
当然,我们可以直接计算这个积分。假设采样数为
积分公式可以改写成卷积的形式
其中
为 R-S 积分的冲激响应(impulse response)
可以证明 R-S 积分传递函数(transfer function)的函数为
$$
H\left(f_X, f_Y\right)=\exp \left(j k z \sqrt{1-\left(\lambda f_X\right)^2-\left(\lambda f_Y\right)^2}\right)
$$
这样,就有两种方法去计算:第一种是基于冲击响应的卷积方法
另一种是基于传递函数的方法
假设对光场的离散采样如下图所示,$X$,
为了简化讨论,考虑一维的情形,对于
其中 $$ \phi_h = k \sqrt{z^2+x^2} $$
其局域空间频率应小于奈奎斯特采样频率 $$ \left| \frac{1}{2 \pi} \frac{\partial \phi_h}{\partial x} \right|_{max} \leq \frac{1}{2 \Delta x} $$
即 $$ \left| \frac{x}{\lambda\sqrt{z^2 + x^2}}\right|_{max} \leq \frac{1}{2 \Delta x} $$
整理得到
上式并不适合衍射距离确定的采样讨论,当距离一定,整理上式得到采样间隔
$$
H\left(f_X\right)=\exp \left(j k z \sqrt{1-\left(\lambda f_X\right)^2}\right) = \exp \left(j \phi_H(f_X)\right)
$$
其中 $ \phi_H(f_X) = k z \sqrt{1-\left(\lambda f_X\right)^2}$ 应该满足以下采样条件
$$
\left|\frac{1}{2 \pi} \frac{\partial \phi_H\left(f_X\right)}{\partial f_X}\right|{\max } \leq \frac{1}{2 \Delta f_X},
$$
得到
$$
\left|\frac{z \lambda f_X}{\sqrt{1 - \left( \lambda f_X\right)^2}} \right|{\max } \leq \frac{1}{2 \Delta f_X},
$$
式子左边是增函数,当
刚好与冲激响应函数相反,同样在衍射距离
再次回到 R-S 积分 $$ U_2(x, y)=\frac{1}{j \lambda} \iint_{\Sigma} U_1(\xi, \eta) \frac{z}{r_{12}} \frac{\exp \left(j k r_{12}\right)}{r_{12}} d \xi d \eta $$
在旁轴近似条件, 衍射角很小,
最后得到菲涅尔衍射的冲激响应 $$ h(x, y) = \frac{1}{j\lambda z}\exp(jkz) \exp(\left[\frac{jk}{2z}\left(x^2+y^2\right)\right] $$ 传递函数,也就是上式的里叶变换 $$ H(f_{X},f_{Y}) =\exp(j k z)\exp\left[ -j\pi\lambda z\left( {f_X}^2 + {f_Y}^2\right)\right] $$
其采样条件可以利用上一节得到的结果在傍轴近似下得到,对于冲激响应 h,当
传播距离
对于传递函数 H
仿真参数设置下图代码段所示,可以计算出在
import numpy as np
from scalardifflib import propagation_tf, propagation_ir
from mathfunc import circ
from matplotlib import pyplot as plt
# unit mm
L = 0.5 # length Lx
Nx = 256 # sample numbers
dx = L/Nx # sample interval delta x
wavelen = 0.5e-6 # wavelength
r = 0.05 # radius of the circle aperture
x = np.linspace(-L/2, L/2-L/Nx, Nx)
x, y = np.meshgrid(x, x)
u1 = circ((x**2+y**2)/r**2)
kernels = ['AS', 'Fresnel' ]
methods = ['TF', 'IR']
z = [1000,2000,4000,20000]
print(' zc = ',str(L*dx/wavelen), 'mm')
propagationfunc = lambda kernel, method, z: propagation_tf(u1, L, wavelen,z,kernel) if method =='TF' else propagation_ir(u1, L, wavelen,z,kernel)
plt.figure(figsize=(8, 8), dpi=300)
figindx = 1
for i in range(len(z)):
for j in range(len(kernels)):
for k in range(len(methods)):
u2 = propagationfunc(kernels[k], methods[j], z[i])
plt.subplot(4,4,figindx)
plt.imshow(np.abs(u2)**2, 'gnuplot')
if (figindx-1) % 4 ==0 :
plt.ylabel('z = '+str(z[i]))
if figindx <= 4 :
plt.title(kernels[k]+'-'+methods[j])
plt.xticks([])
plt.yticks([])
figindx = figindx+1
-
Goodman, Joseph W. Introduction to Fourier optics. Roberts and Company publishers, 2005.
-
Voelz, David George. Computational fourier optics: a MATLAB tutorial. Vol. 534. Bellingham, Washington: SPIE press, 2011.
-
Ersoy, Okan K. Diffraction, Fourier optics and imaging. John Wiley & Sons, 2006..
-
Zhang, Wenhui, et al. "Analysis of numerical diffraction calculation methods: from the perspective of phase space optics and the sampling theorem." JOSA A 37.11 (2020): 1748-1766.