N = 2 * p_obj['N'] smax = p_obj['delta0'] / p_obj['D'] * N c1 = 2 * ((24 / 5) * gamma(6 / 5)) ** (5 / 6) c2 = 4 * c1 / np.pi * (gamma(11 / 6)) ** 2 s_arr = np.linspace(0, smax, N) I0_arr = np.float32(s_arr * 0) I2_arr = np.float32(s_arr * 0) for i in range(len(s_arr)): I0_arr[i] = I0(s_arr[i]) I2_arr[i] = I2(s_arr[i]) i, j = np.int32(N / 2), np.int32(N / 2) [x, y] = np.meshgrid(np.arange(1, N + 0.01, 1), np.arange(1, N + 0.01, 1)) s = np.sqrt((x - i) ** 2 + (y - j) ** 2) C = (In_m(s, p_obj['delta0'] / p_obj['D'] * N , I0_arr) + In_m(s, p_obj['delta0'] / p_obj['D'] * N, I2_arr)) / I0(0) C[round(N / 2), round(N / 2)] = 1 C = C * I0(0) * c2 * (p_obj['Dr0']) ** (5 / 3) / (2 ** (5 / 3)) * (2 * p_obj['wvl'] / (np.pi * p_obj['D'])) ** 2 * 2 * np.pi Cfft = np.fft.fft2(C) S_half = np.sqrt(Cfft) S_half_max = np.max(np.max(np.abs(S_half))) S_half[np.abs(S_half) < 0.0001 * S_half_max] = 0 return S_half
时间: 2023-06-25 19:08:27 浏览: 102
student2p0_obj2p_MFClist_MFC_
这是一段 Python 代码,它计算了一个光学系统的衍射点扩散函数(PSF)的傅里叶变换的一半。PSF描述了光学系统中的点光源如何分布在成像平面上。这个函数的输入是一个字典 p_obj,其中包含了一些光学参数,如波长、系统口径、焦距等。它的输出是一个二维的数组 S_half,表示傅里叶变换的一半。这个数组可以用来计算系统的模糊函数,进而评估系统的成像质量。
阅读全文