首页IT科技傅里叶变换在高通滤波中的应用原理(跟我学Python图像处理丨傅里叶变换之高通滤波和低通滤波)

傅里叶变换在高通滤波中的应用原理(跟我学Python图像处理丨傅里叶变换之高通滤波和低通滤波)

时间2025-04-29 20:52:20分类IT科技浏览3634
导读:摘要:本文讲解基于傅里叶变换的高通滤波和低通滤波。...

摘要:本文讲解基于傅里叶变换的高通滤波和低通滤波            。

本文分享自华为云社区《[Python图像处理] 二十三.傅里叶变换之高通滤波和低通滤波》             ,作者:eastmount                    。

一.高通滤波

傅里叶变换的目的并不是为了观察图像的频率分布(至少不是最终目的)                  ,更多情况下是为了对频率进行过滤      ,通过修改频率以达到图像增强            、图像去噪                   、边缘检测      、特征提取      、压缩加密等目的      。

过滤的方法一般有三种:低通(Low-pass)                   、高通(High-pass)             、带通(Band-pass)      。所谓低通就是保留图像中的低频成分             ,过滤高频成分                   ,可以把过滤器想象成一张渔网      ,想要低通过滤器      ,就是将高频区域的信号全部拉黑                   ,而低频区域全部保留                   。例如            ,在一幅大草原的图像中      ,低频对应着广袤且颜色趋于一致的草原                   ,表示图像变换缓慢的灰度分量;高频对应着草原图像中的老虎等边缘信息            ,表示图像变换较快的灰度分量,由于灰度尖锐过度造成

高通滤波器是指通过高频的滤波器                   ,衰减低频而通过高频                  ,常用于增强尖锐的细节,但会导致图像的对比度会降低             。该滤波器将检测图像的某个区域             ,根据像素与周围像素的差值来提升像素的亮度      。图展示了“Lena             ”图对应的频谱图像                  ,其中心区域为低频部分                  。

接着通过高通滤波器覆盖掉中心低频部分      ,将255两点变换为0             ,同时保留高频部分                   ,其处理过程如下图所示             。

通过高通滤波器将提取图像的边缘轮廓      ,生成如下图所示图像。

# -*- coding: utf-8 -*- import cv2 as cv import numpy as np from matplotlib import pyplot as plt #读取图像 img = cv.imread(Lena.png, 0) #傅里叶变换 f = np.fft.fft2(img) fshift = np.fft.fftshift(f) #设置高通滤波器 rows, cols = img.shape crow,ccol = int(rows/2), int(cols/2) fshift[crow-30:crow+30, ccol-30:ccol+30] = 0 #傅里叶逆变换 ishift = np.fft.ifftshift(fshift) iimg = np.fft.ifft2(ishift) iimg = np.abs(iimg) #显示原始图像和高通滤波处理图像 plt.subplot(121), plt.imshow(img, gray), plt.title(Original Image) plt.axis(off) plt.subplot(122), plt.imshow(iimg, gray), plt.title(Result Image) plt.axis(off) plt.show()

输出结果如下图所示      ,第一幅图为原始“Lena                  ”图                   ,第二幅图为高通滤波器提取的边缘轮廓图像                  。它通过傅里叶变换转换为频谱图像            ,再将中心的低频部分设置为0      ,再通过傅里叶逆变换转换为最终输出图像“Result Image      ”                   。

二.低通滤波

低通滤波器是指通过低频的滤波器                   ,衰减高频而通过低频            ,常用于模糊图像。低通滤波器与高通滤波器相反,当一个像素与周围像素的插值小于一个特定值时                   ,平滑该像素的亮度                  ,常用于去燥和模糊化处理            。如PS软件中的高斯模糊,就是常见的模糊滤波器之一             ,属于削弱高频信号的低通滤波器                   。

下图展示了“Lena             ”图对应的频谱图像                  ,其中心区域为低频部分      。如果构造低通滤波器      ,则将频谱图像中心低频部分保留             ,其他部分替换为黑色0                   ,其处理过程如图所示      ,最终得到的效果图为模糊图像            。

那么      ,如何构造该滤波图像呢?如下图所示                   ,滤波图像是通过低通滤波器和频谱图像形成                   。其中低通滤波器中心区域为白色255            ,其他区域为黑色0      。

低通滤波器主要通过矩阵设置构造      ,其核心代码如下:

rows, cols = img.shape crow,ccol = int(rows/2), int(cols/2) mask = np.zeros((rows, cols, 2), np.uint8) mask[crow-30:crow+30, ccol-30:ccol+30] = 1

通过低通滤波器将模糊图像的完整代码如下所示:

# -*- coding: utf-8 -*- import cv2 import numpy as np from matplotlib import pyplot as plt #读取图像 img = cv2.imread(lena.bmp, 0) #傅里叶变换 dft = cv2.dft(np.float32(img), flags = cv2.DFT_COMPLEX_OUTPUT) fshift = np.fft.fftshift(dft) #设置低通滤波器 rows, cols = img.shape crow,ccol = int(rows/2), int(cols/2) #中心位置 mask = np.zeros((rows, cols, 2), np.uint8) mask[crow-30:crow+30, ccol-30:ccol+30] = 1 #掩膜图像和频谱图像乘积 f = fshift * mask print f.shape, fshift.shape, mask.shape #傅里叶逆变换 ishift = np.fft.ifftshift(f) iimg = cv2.idft(ishift) res = cv2.magnitude(iimg[:,:,0], iimg[:,:,1]) #显示原始图像和低通滤波处理图像 plt.subplot(121), plt.imshow(img, gray), plt.title(Original Image) plt.axis(off) plt.subplot(122), plt.imshow(res, gray), plt.title(Result Image) plt.axis(off) plt.show()

输出结果如图所示                   ,第一幅图为原始“Lena                   ”图            ,第二幅图为低通滤波器模糊处理后的图像      。

点击关注,第一时间了解华为云新鲜技术~

声明:本站所有文章                   ,如无特殊说明或标注                  ,均为本站原创发布                   。任何个人或组织,在未征得本站同意时             ,禁止复制      、盗用                  、采集             、发布本站内容到任何网站、书籍等各类媒体平台             。如若本站内容侵犯了原著者的合法权益                  ,可联系我们进行处理      。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
常见的裸金属型hypervisor是(什么是裸金属服务器 RAKsmart裸金属服务器怎么样) win11开始菜单点击无效(win11无法打开开始菜单怎么办?win11开始菜单打不开的解决方法)