• OpenCV 去噪函数 fastNlMeansDenoising


    CV2.fastNlMeansDenoising(非局部平均去噪)
      L-Means的全称是:Non-Local Means,直译过来是非局部平均,在2005年由Baudes提出,该算法使用自然图像中普遍存在的冗余信息来去噪声。与常用的双线性滤波、中值滤波等利用图像局部信息来滤波不同的是,它利用了整幅图像来进行去噪,以图像块为单位在图像中寻找相似区域,再对这些区域求平均,能够比较好地去掉图像中存在的高斯噪声。与我们以前学习的平滑技术相比这种算法要消耗更多的时间,但是结果很好。对于彩色图像,要先转换到 CIELAB 颜色空间,然后对 L 和 AB 成分分别去噪。

    1 cv2.fastNlMeansDenoising() - 使用单个灰度图像
    2 cv2.fastNlMeansDenoisingColored() - 使用彩色图像。
    3 cv2.fastNlMeansDenoisingMulti() - 用于在短时间内捕获的图像序列(灰度图像)
    4 cv2.fastNlMeansDenoisingColoredMulti() - 与上面相同,但用于彩色图像。
    1 fastNlMeansDenoisingColored( InputArray src, OutputArray dst,
    2                                                float h = 3, float hColor = 3,
    3                                                int templateWindowSize = 7, int searchWindowSize = 21)

    共同参数有:
    • h : 决定过滤器强度。h 值高可以很好的去除噪声,但也会把图像的细节抹去。(取 10 的效果不错)
    • hForColorComponents : 与 h 相同,但使用与彩色图像。(与 h 相同,10)
    • templateWindowSize : 奇数。(推荐值为 7)
    • searchWindowSize : 奇数。(推荐值为 21)

     1 import numpy as np
     2 import cv2
     3 import matplotlib.pyplot as plt
     4 filePath = r'F:\主题一:遥感图像场景分类\val\val\水田\paddy-field_00076.jpg'
     5 img = cv2.imdecode(np.fromfile(filePath,dtype=np.uint8),-1)
     6 dst = cv2.fastNlMeansDenoisingColored(img, None, 10, 10, 7, 21)
     7 
     8 plt.subplot(121), plt.imshow(img)
     9 plt.subplot(122), plt.imshow(dst)
    10 plt.show()

  • 相关阅读:
    一些好用的小工具
    App随机测试之Monkey和Maxim
    Appium如何自动判断浏览器驱动
    最简单的一个Appium测试Android Web APP的代码demo
    pytest使用allure生成测试报告的2种命令
    使用order by in()将快到期的数据排到最上方。
    关于jQuery click()方法重复提交的问题
    关于List removeAll失效的问题
    根据年和月计算对应的天数
    jquery通过监听输入框实现值的自动计算
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/15936057.html
Copyright © 2020-2023  润新知