opencv-python学习笔记六:模糊处理


# -*- coding=GBK -*-
import cv2 as cv
import numpy as np


def blur_demo(image):
    dst=cv.blur(image,(15,3))#水平方向,竖直方向
    cv.imshow("均值模糊",dst)


def median_blur_demo(image):
    dst=cv.medianBlur(image,5) # 表示了5*5的方阵
    cv.imshow("median_blur",dst)


def gaussian_blur_demo(image):
    dst=cv.GaussianBlur(image, (5, 5), 2) # sigmaX:标准差
    cv.imshow("gaussian_blur",dst)


def bilateral_filter_demo(image):
    dst=cv.bilateralFilter(image, 5, 5, 2) #d:邻域直径 sigmaColor:颜色标准差 sigmaSpace:空间标准差
    cv.imshow("bilateral_filter",dst)


def custom_blur_demo(image):
    #kernel=np.ones([5,5],np.float32)/25
    kernel=np.array([[0,-1,0],[-1,5,-1],[0,-1,0]],np.float32) # 锐化
    dst=cv.filter2D(image, -1, kernel=kernel)
    cv.imshow("custom_blur_demo",dst)


src=cv.imread("D:/Documents/Pictures/ex2.jpeg")
cv.namedWindow("input image",cv.WINDOW_AUTOSIZE)
cv.imshow("input image",src)

blur_demo(src)
median_blur_demo(src)
gaussian_blur_demo(src)
bilateral_filter_demo(src)


# custom_blur_demo(src)


cv.waitKey(0)

cv.destroyAllWindows()

使用低通滤波器可以达到图像模糊的目的。这对与去除噪音很有帮助。其实就是去除图像中的高频成分(比如:噪音,边界)。所以边界也会被模糊一 点。(当然,也有一些模糊技术不会模糊掉边界)。

cv.blur是由一个归一化卷积框完成的。他只是用卷积框覆盖区域所有像素的平均值来代替中心元素。如果不想使用归一化卷积框,可以使用cv2.boxFilter() ,需要传入参数normalize=False

cv.medianBlur顾名思义就是用与卷积框对应像素的中值来替代中心像素的值。这个滤波器经常用来去除椒盐噪声。前面的滤波器都是用计算得到的一个新值来取代中心像素的值,而中值滤波是用中心像素周围(也可以使他本身)的值来取代他。 他能有效的去除噪声。卷积核的大小也应该是一个奇数。

cv.GaussianBlur把卷积核换成高斯核(简单来说,方框不变,原来每个方框的值是相等的,现在里面的值是符合高斯分布的,方框中心的值最大,其余方框根据距离中心元素的距离递减,构成一个高斯小山包。
原来的求平均数现在变成求加权平均数)。实现的函数是cv2.GaussianBlur()。需要指定高斯核的宽和高(必须是奇数)。以及高斯函数沿 X,Y 方向的标准差。如果我们只指定了 X 方向的的标准差,Y 方向也会取相同值。如果两个标准差都是0,那么函数会根据核函数的大小自己计算。高斯滤波可以有效的从图像中去除高斯噪音。如果你愿意的话,你也可以使用函数 cv2.getGaussianKernel() 自己构建一个高斯核。

函数 cv2.bilateralFilter() (双边滤波)能在保持边界清晰的情况下有效的去除噪音。但是这种操作与其他滤波器相比会比较慢。我们已经知道高斯滤波器是求中心点邻近区域像素的高斯加权平均值。这种高斯滤波器只考虑像素之间的空间关系,而不会考虑像素值之间的关系(像素的相似度)。所以这种方法不会考虑一个像素是否位于边界。因此边界也会别模糊掉,而这正不是我们想要。 双边滤波在同时使用空间高斯权重和灰度值相似性高斯权重。空间高斯函数确保只有邻近区域的像素对中心点有影响,灰度值相似性高斯函数确保只有与中心像素灰度值相近的才会被用来做模糊运算。所以这种方法会确保边界不会被模糊掉,因为边界处的灰度值变化比较大。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值