OpenCV学习笔记11-图像平滑

目标

  • 使用不同的低通滤波器对图像进行模糊,去除噪音(高通滤波寻找图像边缘);
  • 使用自定义的滤波器对图像进行卷积(2D 卷积)。

2D卷积(平均滤波器)

cv.filter2D(src, ddepth, kernel) -> dst

  • when ddepth=-1, the output image will have the same depth as the source.

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('opencv_logo.jpg')

kernel = np.ones((5,5), np.float32)/25  #滤波器
dst = cv2.filter2D(img, -1, kernel)     #卷积

plt.subplot(121), plt.imshow(img), plt.title('Original')
plt.xticks([]), plt.yticks([])

plt.subplot(122), plt.imshow(dst), plt.title('Averaging')
plt.xticks([]), plt.yticks([])

plt.show()

这里写图片描述


1.均值模糊(平滑)

cv2.blur(src, ksize[, dst[, anchor[, borderType]]]) -> dst

  • src为输入图像矩阵;
  • kszie是模糊的窗口大小,例如(3,3),(5,5);
  • dst是输出图像矩阵。

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('opencv_logo.jpg')
blur = cv2.blur(img, (5,5))  #均值模糊

plt.subplot(121), plt.imshow(img), plt.title('Original')
plt.xticks([]), plt.yticks([])

plt.subplot(122), plt.imshow(blur), plt.title('Blur')
plt.xticks([]), plt.yticks([])

plt.show()

这里写图片描述


2.高斯模糊

cv2.GaussianBlur(src, ksize, sigmaX[, dst[, sigmaY[, borderType]]]) -> dst

  • src是输入图像矩阵;
  • kszie是平滑的窗口大小,必须为奇数;
  • sigmaX为标准差参数,越大则高斯函数的峰值越平稳。

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('opencv_logo.jpg')
blur = cv2.GaussianBlur(img, (5,5), 0)  #高斯模糊,0为标准差

plt.subplot(121), plt.imshow(img), plt.title('Original')
plt.xticks([]), plt.yticks([])

plt.subplot(122), plt.imshow(blur), plt.title('GSBlur')
plt.xticks([]), plt.yticks([])

plt.show()

这里写图片描述


3.中值滤波

中值滤波器是一个常用的、有较好去噪声能力的滤波器。

cv2.medianBlur(src, ksize[, dst]) -> dst

  • src是输入图像矩阵;
  • ksize是窗口大小,应该为奇数。

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('opencv_logo.jpg')
blur = cv2.medianBlur(img, 5)    #中值模糊

plt.subplot(121), plt.imshow(img), plt.title('Original')
plt.xticks([]), plt.yticks([])

plt.subplot(122), plt.imshow(blur), plt.title('medianBlur')
plt.xticks([]), plt.yticks([])

plt.show()

这里写图片描述


4.双边滤波

去噪的同时,保留边缘的信息。速度较慢,但效果超棒的!

cv2.bilateralFilter(src, d, sigmaColor, sigmaSpace[, dst[, borderType]]) -> dst

  • src为输入图像矩阵;
  • d为滤波过程中使用的像素邻域直径;
  • sigmaColor为灰度值相似性高斯函数标准差;
  • sigmaSpace为空间高斯函数标准差。

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('opencv_logo.jpg')
blur = cv2.bilateralFilter(img, 9, 75, 75)  #双边滤波

plt.subplot(121), plt.imshow(img), plt.title('Original')
plt.xticks([]), plt.yticks([])

plt.subplot(122), plt.imshow(blur), plt.title('Blur')
plt.xticks([]), plt.yticks([])

plt.show()

这里写图片描述


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值