zoukankan      html  css  js  c++  java
  • 【DW打卡-计算机视觉基础】04_图像滤波

    4.2 学习目标

    • 了解图像滤波的分类和基本概念

    • 理解均值滤波/方框滤波、高斯滤波的原理

    • 掌握OpenCV框架下滤波API的使用

    4.4 算法理论介绍

    4.4.1 均值滤波、方框滤波

    1. 滤波分类

    线性滤波: 对邻域中的像素的计算为线性运算时,如利用窗口函数进行平滑加权求和的运算,或者某种卷积运算,都可以称为线性滤波。常见的线性滤波有:均值滤波、高斯滤波、盒子滤波、拉普拉斯滤波等等,通常线性滤波器之间只是模版系数不同。

    非线性滤波: 非线性滤波利用原始图像跟模版之间的一种逻辑关系得到结果,如最值滤波器,中值滤波器。比较常用的有中值滤波器和双边滤波器。

    2. 方框(盒子)滤波

    方框滤波是一种非常有用的线性滤波,也叫盒子滤波,均值滤波就是盒子滤波归一化的特殊情况。
    应用: 可以说,一切需要求某个邻域内像素之和的场合,都有方框滤波的用武之地,比如:均值滤波、引导滤波、计算Haar特征等等。
    在原理上,是采用一个卷积核与图像进行卷积.
    可见,归一化了就是均值滤波;不归一化则可以计算每个像素邻域上的各种积分特性,方差、协方差,平方和等等。

    3. 均值滤波

    均值滤波的应用场合:
    根据冈萨雷斯书中的描述,均值模糊可以模糊图像以便得到感兴趣物体的粗略描述,也就是说,去除图像中的不相关细节,其中“不相关”是指与滤波器模板尺寸相比较小的像素区域,从而对图像有一个整体的认知。即为了对感兴趣的物体得到一个大致的整体的描述而模糊一幅图像,忽略细小的细节。

    均值滤波的缺陷:
    均值滤波本身存在着固有的缺陷,即它不能很好地保护图像细节,在图像去噪的同时也破坏了图像的细节部分,从而使图像变得模糊,不能很好地去除噪声点。特别是椒盐噪声。

    均值滤波是上述方框滤波的特殊情况,均值滤波方法是:对待处理的当前像素,选择一个模板,该模板为其邻近的若干个像素组成,用模板的均值(方框滤波归一化)来替代原像素的值。公式表示为:

    4.4.1 高斯滤波

    应用: 高斯滤波是一种线性平滑滤波器,对于服从正态分布的噪声有很好的抑制作用。在实际场景中,我们通常会假定图像包含的噪声为高斯白噪声,所以在许多实际应用的预处理部分,都会采用高斯滤波抑制噪声,如传统车牌识别等。

    高斯滤波和均值滤波一样,都是利用一个掩膜和图像进行卷积求解。不同之处在于:均值滤波器的模板系数都是相同的为1,而高斯滤波器的模板系数,则随着距离模板中心的增大而系数减小(服从二维高斯分布)。所以,高斯滤波器相比于均值滤波器对图像个模糊程度较小,更能够保持图像的整体细节。

    二维高斯分布
    高斯分布公式终于要出场了!
    在这里插入图片描述

    """
    """
    原文链接 https://www.cnblogs.com/sunblingbling/p/12596051.html
    """

    代码

    import cv2
    import numpy as np
    from PIL import Image, ImageDraw, ImageFont
    
    #均值滤波
    def blur(source):
    
        img = cv2.blur(source, (10,10))
    
        cv2img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
        pilimg = Image.fromarray(cv2img)
        draw = ImageDraw.Draw(pilimg) # 图片上打印
        font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8") # 参数1:字体文件路径,参数2:字体大小
        draw.text((0, 0), "均值滤波", (255, 0, 0), font=font) # 参数1:打印坐标,参数2:文本,参数3:字体颜色,参数4:字体
    
        # PIL图片转cv2 图片
        cv2charimg = cv2.cvtColor(np.array(pilimg), cv2.COLOR_RGB2BGR)
        cv2.imshow("blur", cv2charimg)
    #中值滤波
    def medianBlur(source):
        img= cv2.medianBlur(source, 3)
        cv2img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
        pilimg = Image.fromarray(cv2img)
    
        draw = ImageDraw.Draw(pilimg) # 图片上打印
        font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8") # 参数1:字体文件路径,参数2:字体大小
        draw.text((0, 0), "中值滤波", (255, 0, 0), font=font) # 参数1:打印坐标,参数2:文本,参数3:字体颜色,参数4:字体
        # PIL图片转cv2 图片
        cv2charimg = cv2.cvtColor(np.array(pilimg), cv2.COLOR_RGB2BGR)
        cv2.imshow("medianBlur", cv2charimg)
    #方框滤波
    def BoxFilter(source):
    
        img = cv2.boxFilter(source, -1, (5,5), normalize=1)
        cv2img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
        pilimg = Image.fromarray(cv2img)
    
        draw = ImageDraw.Draw(pilimg) # 图片上打印
        font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8") # 参数1:字体文件路径,参数2:字体大小
        draw.text((0, 0), "方框滤波", (255, 0, 0), font=font) # 参数1:打印坐标,参数2:文本,参数3:字体颜色,参数4:字体
        # PIL图片转cv2 图片
        cv2charimg = cv2.cvtColor(np.array(pilimg), cv2.COLOR_RGB2BGR)
        cv2.imshow("boxFilter", cv2charimg)
    #高斯滤波
    def GaussianBlur(source):
        img = cv2.GaussianBlur(source, (3,3), 0)
        cv2img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
        pilimg = Image.fromarray(cv2img)
    
        draw = ImageDraw.Draw(pilimg) # 图片上打印
        font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8") # 参数1:字体文件路径,参数2:字体大小
        draw.text((0, 0), "高斯滤波", (255, 0, 0), font=font) # 参数1:打印坐标,参数2:文本,参数3:字体颜色,参数4:字体
        # PIL图片转cv2 图片
        cv2charimg = cv2.cvtColor(np.array(pilimg), cv2.COLOR_RGB2BGR)
        cv2.imshow("GaussianBlur", cv2charimg)
    
    #高斯边缘检测
    def GaussianSideDetect(source):
        sobelX = cv2.Sobel(source,cv2.CV_64F,1,0)#x方向的梯度
        sobelY = cv2.Sobel(source,cv2.CV_64F,0,1)#y方向的梯度
    
        sobelX = np.uint8(np.absolute(sobelX))#x方向梯度的绝对值
        sobelY = np.uint8(np.absolute(sobelY))#y方向梯度的绝对值
    
        img = cv2.bitwise_or(sobelX,sobelY)#
        cv2img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
        pilimg = Image.fromarray(cv2img)
    
        draw = ImageDraw.Draw(pilimg) # 图片上打印
        font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8") # 参数1:字体文件路径,参数2:字体大小
        draw.text((0, 0), "高斯边缘检测", "green", font=font) # 参数1:打印坐标,参数2:文本,参数3:字体颜色,参数4:字体
    
        # PIL图片转cv2 图片
        cv2charimg = cv2.cvtColor(np.array(pilimg), cv2.COLOR_RGB2BGR)
        cv2.imshow("GaussianSideDetect", cv2charimg)
    
    if __name__ == '__main__':
        img = cv2.imread('./00_dog.jpg', cv2.IMREAD_UNCHANGED)
        cv2.imshow("img", img)
        blur(img)
        medianBlur(img)
        BoxFilter(img)
        GaussianBlur(img)
        GaussianSideDetect(img)
    
        cv2.waitKey(0)
        cv2.destroyAllWindows()
    

    输出效果

    你不逼自己一把,你永远都不知道自己有多优秀!只有经历了一些事,你才会懂得好好珍惜眼前的时光!
  • 相关阅读:
    [NodeJS] Node.js 编码转换
    [SublimeText] 如何创建工程
    浏览器 user-agent 字符串的故事
    [Ubuntu] geoip-bin 程序包
    在 Ubuntu 中安装 MySQL 指南
    在 Ubuntu 13.10 安装 PyCharm 3.0.1 & Oracle JDK
    [Command] lrzsz
    [Linux] 如何修改 Linux 主机名
    如何在 Ubuntu 中安装 Node.js
    [Linux] 修改用户名密码
  • 原文地址:https://www.cnblogs.com/zhazhaacmer/p/15321307.html
Copyright © 2011-2022 走看看