OpenCV 高通滤波

高通滤波

低频、高频

OpenCV 高通滤波

滤波

OpenCV 高通滤波

频域滤波

OpenCV 高通滤波

代码示例

import cv2
import numpy as np
import matplotlib.pyplot as plt
	#1.导入图片并进行傅里叶变换
img = cv2.imread('./hanser.jpg',0)
f = np.fft.fft2(img)
fshift = np.fft.fftshift(f)
	#2.剔除低频,通高频
rows,cols = img.shape
crow,ccol = int(rows/2),int(cols/2)
fshift[crow-30:crow+30,ccol-30:ccol+30] = 0
	#3.反傅里叶变换
ishift = np.fft.ifftshift(fshift)
iimg = np.abs(np.fft.ifft2(ishift))
	#4.图片展示
plt.subplot(121),plt.imshow(img,cmap='gray')
plt.title('original'),plt.axis('off')
plt.subplot(122),plt.imshow(iimg,cmap='gray')
plt.title('iimg'),plt.axis('off')
plt.show()

OpenCV 高通滤波

OpenCV 高通滤波OpenCV 高通滤波 机械搬砖工 发布了56 篇原创文章 · 获赞 6 · 访问量 1709 私信 关注
上一篇:BZOJ 5300: [Cqoi2018]九连环 打表+FFT


下一篇:numpy拟合的傅立叶级数:fft与编码