-
题目分类:math
-
题目分值:150
小 P 在一教做傅里叶光学实验时,在实验室电脑的模拟程序里发现了这么一张的图片:
数理基础并不扎实的小 P 并不知道什么东西成像会是这个样子:又或许什么东西都不是,毕竟这只是模拟 ... 但可以确定的是,这些看似奇怪的花纹里确实隐藏着一些信息,或许是地下金矿的藏宝图也未可知。
对图像二维傅里叶变换就结束了。灵感来自于中国科学技术大学三级大学物理实验“傅里叶光学”。
用 Python 的解法:
import numpy as np
import cv2 as cv
from matplotlib import pyplot as plt
img = cv.imread('./4f_system_middle.bmp', 0)
f = np.fft.fft2(img)
logf = 20*np.log(np.abs(f))
plt.imshow(logf, 'gray')
注意 Python 变换之后可能会有一个点值非常大,画图时导致剩下的图像看不出来,手动修复或对数做图(这也是 FFT 的基本操作)即可。对于(逆)变换之后得到的 f ,做图时取实部还是虚部还是模可能需要都试一下,比如取实部只能看到一点线条,取模就能很好地看到图像,但这个应该也不难想到。
用商业软件 Mathematica 的解法:
嗯,就这样结束了。
题目中傅里叶光学是提示,文件名意思是 4F 成像系统中间,就对应物的傅里叶变换平面,也算是提示了,但或许对非物理专业的同学还是有点脑洞吧。
相关模拟可以参考 Matlab 官方文档。本题的图片其实也是通过 Matlab 制作的。
为什么题目中说是模拟呢,因为题目中的图片取的是物傅里叶变换的实部,而一般实验能直接观测光强(用 CCD )和相位分布(用 SH波前探测器),看电场实部或者虚部还真没听说过。
这么做的原因是衍射光强分布不同地方差几个量级,如果直接把光强存到图片里就损失了大量的信息,根本无法重构:你可以把圆孔衍射的光强分布存图片试一下,发现结果会肉眼可见地令人失望:
或许这方面图像处理有更好的方法,不过我不太懂。
就算像本题这样取了实部,其实强度信息也基本损失完了,所以图片上除了黑点就是白点,几乎没有中间颜色。但因为这种存储方式仍然包含了变换后图的相位信息,所以仍能成功重构图像,因为图像的细节信息其实在相位而不是强度中。
另外,真实情况的零频率分量是在成像中间的,模拟中其实需要进行 fftshift 操作,鉴于这里的图像根本区分不出中间还是边上,就也省去了。
本人数理基础也并不扎实,所以具体物理细节还以权威参考资料为准。