Python调用OpenCV滤波

21 篇文章 2 订阅
21 篇文章 0 订阅

这一篇记录几种OpenCV提供的滤波函数,包括2D卷积、平均滤波、高斯滤波、中值滤波和双边滤波。

1、2D卷积

2D卷积使用的是OpenCV提供的filter2D()函数,该函数需要传入一个卷积核,这个卷积核可以通过numpy来构造:

import numpy as np
import cv2 as cv

src = cv.imread("D:/lena.bmp")
kernel = np.ones((5,5),np.float32)/25
dst = cv.filter2D(src,-1,kernel)
cv.imshow('filter2D', dst)
cv.waitKey(0)
cv.destroyAllWindows()

2、平均滤波blur

OpenCV的平均滤波用的是blur:

import numpy as np    
import cv2 as cv

src = cv.imread("D:/lena.bmp")
dst = cv.blur(src,(5,5))
cv.imshow('filter2D', dst)
cv.waitKey(0)
cv.destroyAllWindows()

3、高斯模糊

高斯模糊的函数是cv2.GaussianBlur():

import numpy as np    
import cv2 as cv

src = cv.imread("D:/lena.bmp")
dst = cv.GaussianBlur(src, (5,5), 0)
cv.imshow('filter2D', dst)
cv.waitKey(0)
cv.destroyAllWindows()

代码中之定义了X轴的标准差为0,所以在使用的时候OpenCV会把Y轴的标准差也设置为0,然后因为标准差为零,所以会函数会根据核的大小自己计算。也就是说,如果只定义了X轴的标准差,则Y轴会与X轴一样,如果定义标准差为0,那么函数就会自己计算标准差。

4、中值模糊

中值模糊是比较适合椒盐噪声的,其函数为cv2.medianBlur:

import numpy as np    
import cv2 as cv

src = cv.imread("D:/lena.bmp")
dst = cv.medianBlur(src, 5)
cv.imshow('filter2D', dst)
cv.waitKey(0)
cv.destroyAllWindows()

 

5、双边滤波

哈,这个是磨皮滤波,OpenCV的双边滤波是cv2.bilateralFilter(),这个函数有四个输入,分别是原图、尺寸、颜色标准差和空间标准差:

import numpy as np
import cv2 as cv

src = cv.imread("D:/lena.bmp")
dst = cv.bilateralFilter(src, 9, 50, 100)
cv.imshow('filter2D', dst)
cv.waitKey(0)
cv.destroyAllWindows()

之所以叫它磨皮滤波,这是因为它会将相对平坦处平滑掉,然后保持边缘不变,这样的话变化较小的纹理会被模糊掉,也就是起到类似磨皮的效果哈,不信可以找张没开美颜的自拍试试...

可以注意lena的脸和肩膀...23333....

只记得花开碧树

可曾顾衾冷锦疏

最难忘 应是来时路

那会儿身影

不斜也扶

到如今

凭谁问甘苦

梦中事

笑是真笑

哭是真哭

-- 汪国真 《在梦里,我遇见了你》

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OpenCV是一个计算机视觉库,支持多种编程语言,其中包括Python。它提供了一个丰富的API来实现图像处理任务,包括小波滤波。 小波滤波是一种图像处理方法,可以用来降噪、去模糊等。使用OpenCVPython接口可以很方便地实现小波滤波,只需要调用cv2.dwt2()函数并传入要处理的图像即可。 代码示例: ``` import cv2 import numpy as np img = cv2.imread('input.jpg') img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) mode = cv2.DXT_FORWARD img_coeffs = cv2.dwt2(img, mode) ``` 这样就可以实现对图像的小波滤波处理了。 ### 回答2: 小波滤波是一种常用于图像处理的滤波方法,其使用了小波函数来对图像进行变换和滤波。在OpenCVPython库中,可以使用cv2库中的函数进行小波滤波操作。 首先,需要导入cv2库并读取待处理的图像。然后,可以使用cv2的函数cv2.dwt2()来进行小波变换,该函数接受两个参数:待处理的图像和一个小波基。常用的小波基有haar、db1、sym2等,可以根据具体需求选择合适的小波基。 将待处理的图像和小波基传入cv2.dwt2()函数后,会返回一个元组,其中包含了低频部分(LL)、水平细节部分(LH)、垂直细节部分(HL)和对角细节部分(HH)。可以根据需要选择保留哪些细节信息。 接下来,可以使用cv2的函数cv2.idwt2()来进行小波逆变换,该函数接受三个参数:低频部分(LL)、水平细节部分(LH)、垂直细节部分(HL)和对角细节部分(HH)。将这些参数传入cv2.idwt2()函数后,会返回原始的图像。 最后,可以使用cv2的函数cv2.imshow()和cv2.waitKey()来显示和保存处理后的图像。cv2.imshow()用于显示图像窗口,而cv2.waitKey()用于等待用户按下按键。最后,使用cv2的函数cv2.imwrite()可以将滤波后的图像保存到本地。 综上所述,使用OpenCVPython库可以方便地进行小波滤波操作,通过cv2.dwt2()函数进行小波变换,选择保留的细节信息,再通过cv2.idwt2()函数进行小波逆变换,最后使用cv2.imshow()和cv2.imwrite()函数来显示和保存图像。 ### 回答3: 小波滤波是一种在图像处理中常用的滤波方法,可以有效地去除图像中的噪声和细节,同时保留图像的主要特征。OpenCV是一个强大的图像处理库,提供了对小波滤波的支持。 在Python中使用OpenCV进行小波滤波的步骤如下: 1. 导入必要的库:首先需要导入OpenCV和numpy库,因为OpenCV中的小波滤波函数需要numpy数组作为输入和输出。 2. 读取图像:使用OpenCV的imread函数读取要进行滤波的图像,并将其转换为numpy数组。 3. 小波变换:使用OpenCV的函数cv2.dwt对图像进行小波变换。该函数在水平和垂直方向上对图像进行分解,得到低频分量和高频分量。 4. 滤波:对图像的高频分量进行滤波,可以选择不同的滤波器进行滤波。常用的滤波器有Haar滤波器、Daubechies滤波器等。 5. 逆小波变换:将滤波后的低频分量和滤波后的高频分量进行逆小波变换,得到滤波后的图像。 6. 显示和保存滤波后的图像:使用OpenCV的imshow函数显示滤波后的图像,并使用imwrite函数保存滤波后的图像。 小波滤波是一种非常有用的图像处理技术,可以应用于很多领域,比如图像去噪、图像压缩等。在使用OpenCV进行小波滤波时,需要对小波变换和滤波器有一定的了解,并选择合适的参数和滤波器来进行滤波

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值