【OpenCV-Python】:图像高通滤波、低通滤波、带通滤波实现

✨博客主页:王乐予🎈
✨年轻人要:Living for the moment(活在当下)!💪
🏆推荐专栏:【图像处理】【千锤百炼Python】【深度学习】【排序算法

😺一、高通滤波

🐶1.1 原理

顾名思义,高通滤波就是允许高频信息通过,低频信息截断的滤波方式。

🐶1.2 程序设计

import cv2
import numpy as np
import matplotlib.pyplot as plt
original = cv2.imread(r'C:\Users\Lenovo\Desktop\lena1.jpg', 0)

dft = cv2.dft(np.float32(original), flags=cv2.DFT_COMPLEX_OUTPUT)   # 傅里叶变换
fshift = np.fft.fftshift(dft)    # 低频移至中心

# 定义高通滤波器
# 设置掩膜
rows, cols = original.shape
crow, ccol = int(rows / 2), int(cols / 2)   # 中心位置

mask = np.ones((rows, cols, 2), np.uint8)
mask[crow-30:crow+30, ccol-30:ccol+30] = 0

f = fshift * mask     # 将掩模与傅里叶变化后的图像相乘,保留四周部分,即保留高频部分

ishift = np.fft.ifftshift(f)       # 低频移回
img_back = cv2.idft(ishift)     # 傅里叶逆变换

img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])   # 频域转回空域

plt.subplot(121)
plt.title('original_img')
plt.axis('off')
plt.imshow(original, cmap='gray')

plt.subplot(122)
plt.title('filtering_img')
plt.axis('off')
plt.imshow(img_back, cmap='gray')

plt.show()

🐶1.3 结果可视化

在这里插入图片描述

😺二、低通滤波

🐶2.1 原理

顾名思义,低通滤波就是允许低频信息通过,高频信息截断的滤波方式。

🐶2.2 程序设计

import cv2
import numpy as np
import matplotlib.pyplot as plt
original = cv2.imread(r'C:\Users\Lenovo\Desktop\lena1.jpg', 0)

dft = cv2.dft(np.float32(original), flags=cv2.DFT_COMPLEX_OUTPUT)   # 傅里叶变换
fshift = np.fft.fftshift(dft)    # 低频移至中心

# 定义低通滤波器
# 设置掩膜
rows, cols = original.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     # 将掩模与傅里叶变化后的图像相乘,保留四周部分,即保留低频部分

ishift = np.fft.ifftshift(f)       # 低频移回
img_back = cv2.idft(ishift)     # 傅里叶逆变换

img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])   # 频域转回空域

plt.subplot(121)
plt.title('original_img')
plt.axis('off')
plt.imshow(original, cmap='gray')

plt.subplot(122)
plt.title('filtering_img')
plt.axis('off')
plt.imshow(img_back, cmap='gray')

plt.show()

🐶2.3 结果可视化

在这里插入图片描述

😺三、带通滤波

🐶3.1 原理

顾名思义,带通滤波就是允许低频与高频之间的信息通过,其他信息被阻断。

🐶3.2 程序设计

import cv2
import numpy as np
import matplotlib.pyplot as plt
import math
original = cv2.imread(r'C:\Users\Lenovo\Desktop\lena1.jpg', 0)

dft = cv2.dft(np.float32(original), flags=cv2.DFT_COMPLEX_OUTPUT)   # 傅里叶变换
fshift = np.fft.fftshift(dft)    # 低频移至中心

# 定义带通滤波器
# 设置掩膜
rows, cols = original.shape
crow, ccol = int(rows / 2), int(cols / 2)   # 中心位置

w = 30          # 带宽
radius = 30     # 带中心到频率平面原点的距离

mask = np.ones((rows, cols, 2), np.uint8)

for i in range(0, rows):
    for j in range(0, cols):
        d = math.sqrt(pow(i - crow, 2) + pow(j - ccol, 2))  # 计算(i, j)到中心点的距离
        if radius - w / 2 < d < radius + w / 2:
            mask[i, j, 0] = mask[i, j, 1] = 0
        else:
            mask[i, j, 0] = mask[i, j, 1] = 1


f = fshift * mask

ishift = np.fft.ifftshift(f)       # 低频移回
img_back = cv2.idft(ishift)     # 傅里叶逆变换

img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])   # 频域转回空域

plt.subplot(121)
plt.title('original_img')
plt.axis('off')
plt.imshow(original, cmap='gray')

plt.subplot(122)
plt.title('filtering_img')
plt.axis('off')
plt.imshow(img_back, cmap='gray')

plt.show()

🐶3.3 结果可视化

在这里插入图片描述

OpenCV中提供了多种高通滤波低通滤波的函数,下面分别介绍其中的几种。 1. 高斯滤波(低通滤波) 高斯滤波是一种常用的低通滤波器,可以通过对信号进行平滑处理来去除高频噪声,保留信号中的低频信息。在OpenCV中,可以使用`cv2.GaussianBlur`函数实现高斯滤波。 ```python blurred = cv2.GaussianBlur(image, (ksize, ksize), sigmaX) ``` 其中,`image`为输入图像,`ksize`为滤波器的大小,`sigmaX`为高斯核的标准差。 2. 拉普拉斯滤波(高通滤波) 拉普拉斯滤波是一种常用的高通滤波器,可以通过增强信号的高频成分来增强图像的边缘信息。在OpenCV中,可以使用`cv2.Laplacian`函数实现拉普拉斯滤波。 ```python laplacian = cv2.Laplacian(image, cv2.CV_32F, ksize) ``` 其中,`image`为输入图像,`cv2.CV_32F`表示输出图像的数据类型为32位浮点数,`ksize`为滤波器的大小。 3. Sobel滤波(高通滤波) Sobel滤波也是一种常用的高通滤波器,它可以通过检测图像中的边缘来增强图像的高频成分。在OpenCV中,可以使用`cv2.Sobel`函数实现Sobel滤波。 ```python sobelx = cv2.Sobel(image, cv2.CV_32F, 1, 0, ksize) sobely = cv2.Sobel(image, cv2.CV_32F, 0, 1, ksize) ``` 其中,`image`为输入图像,`cv2.CV_32F`表示输出图像的数据类型为32位浮点数,`1`和`0`表示对x和y方向进行滤波,`ksize`为滤波器的大小。 总的来说,OpenCV提供了多种高通滤波低通滤波的函数,具体使用哪种滤波器取决于信号的特性和需要的处理效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王乐予

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值