Python OpenCV学习之图像滤波详解

作者:一个热爱学习的深度渣渣 时间:2021-09-17 18:49:36 

背景

图像滤波的作用简单来说就是将一副图像通过滤波器得到另一幅图像;明确一个概念,滤波器又被称为卷积核,滤波的过程又被称为卷积;实际上深度学习就是训练许多适应任务的滤波器,本质上就是得到最佳的参数;当然在深度学习之前,也有一些常见的滤波器,本篇主要介绍这些常见的滤波器;

一、卷积相关概念

卷积核大小一般为奇数的原因:

1、增加padding的原因;

2、保证锚点在中间,防止位置发生偏移;

卷积核大小的影响:卷积核越大,感受野越大,提取的特征越好,同时计算量也越大;

边界扩充(padding)作用:使得输出数据的尺寸与输入相等;

计算公式:

N = (W - F + 2P)/ S + 1

  • N:输出图像大小

  • W:原图大小

  • F:卷积核大小

  • P:扩充尺寸

  • S:步长大小

二、卷积实战

首先介绍两个简单的滤波:低通滤波与高通滤波;

低通滤波:低于阈值的可通过,去除噪音或平滑图像;

高通滤波:高于阈值的可 通过,用于边缘检测;

函数原型:

filter2D(src,ddepth,kernel,[anchor,delta,borderType])

ddepth:位深,一般设定为-1;

代码案例:

kernel = np.ones((5, 5), np.float32) / 25
result = cv2.filter2D(img, -1, kernel)

这是一个平均卷积,起到一个降噪的作用,但效果并不明显;

三、均值滤波

首先介绍一个方盒滤波,实际上就是全为1的卷积核乘以权重a;

函数原型:boxFilter(src,ddepth,ksize,anchor,normalize,borderType)

说明:当normalize为True时,乘以1/W*H,也就是均值滤波,所以一般不用这个滤波函数;

均值滤波函数原型:blur(src,ksize,[anchor,borderType])

注意:一般均值滤波就是使用这个API;

代码案例:

result = cv2.blur(img, 5)

四、高斯滤波

原理:越靠近中心,权重越大,离中心越远,权重越小;

函数原型:

GaussianBlur(img,kernel,sigmaX,[sigmaY,…])

说明:对效果有影响的参数为kernel和sigmaX,这两者越大图像平滑(模糊)的效果会越明显;

代码案例:

gauss = cv2.imread('gaussian.png')
result = cv2.GaussianBlur(gauss, (5, 5), 5)
cv2.imshow('org', gauss)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

从图中可看出,处理后高斯噪点减少了,但整体图像也变模糊了;

五、中值滤波

本质:取中间值作为卷积结果;

作用:对胡椒噪音有很好的处理效果;

函数原型:

medianBlur(img,ksize)

代码案例:

img = cv2.imread('papper.png')
result = cv2.medianBlur(img, 5)
cv2.imshow('org', img)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

从上图可以看出,效果是相当不错的;

六、双边滤波

作用:可以保留边缘,同时对边缘内的区域进行平滑处理;(主要进行美颜)

函数原型:

bilateralFilter(img,d,sigmaColor,sigmaSpace)

案例代码:

img = cv2.imread('1.jpg')
result = cv2.bilateralFilter(img, 9, 50, 50)
cv2.imshow('org', img)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

从图中可以看出,美颜效果是比较明显的,并且对于边缘轮廓也处于能接受范围;

七、Sobel算子

上述介绍的几种滤波均为低通滤波,接下来介绍高通滤波,最主要作用是检测边缘;

实现步骤:

x轴方向求导 —— y轴方向求导 —— 最终结果为二者相加

函数原型:

Sobel(src,ddepth,dx,dy,ksize=3,…)

代码案例:

chess = cv2.imread('chess.png')
# 求y方向边缘
dy = cv2.Sobel(chess, cv2.CV_64F, 1, 0, ksize=5)
# 求x方向边缘
dx = cv2.Sobel(chess, cv2.CV_64F, 0, 1, ksize=5)
# 二者相加
result = dy + dx

cv2.imshow('chess', chess)
cv2.imshow('dy', dy)
cv2.imshow('dx', dx)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

从上图可以明显看出,当dx设置为1时,求得y方向上的边缘信息,反之也是,最终二者相加的结果也就是Sobel算子的结果。不能一开始就设定dx,dy为1,这样子不能达到该效果;

八、Scharr算子

定义:与Sobel类似,但使用的kernel值不同,并且只能为3x3,只能求x方向或y方向一个方向的边缘信息;

函数原型:

Scharr(src,ddepth,dx,dy)

在这里就不演示了,该算子不常用,主要优点是能检测到不明显的边缘,当Sobel的ksize设置为-1时等同;

九、拉普拉斯算子

优点:可同时求得两个方向的边缘;

缺点:对噪音比较敏感,一般需要先进行去噪在调用拉普拉斯算子;

函数原型:

Laplacian(img,ddepth,ksize=1)

代码案例:

chess = cv2.imread('chess.png')
result = cv2.Laplacian(chess, cv2.CV_64F, ksize=5)

cv2.imshow('chess', chess)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

从效果上看,比起Sobel步骤更加简单,并且效果也比较好,缺点就是如果噪声过多的话效果会比较差;

十、Canny算法

实现步骤:

1、使用5x5高斯滤波消除噪音;

2、使用Sobel计算图像梯度的方向(0°、45°、90°、135°);

3、取局部极大值;

4、阈值计算;

函数原型:

Canny(img,minVal,maxVal,…)

其中的minVal和maxVal代表边缘的阈值,两者差值过大的话会损失一定的边缘信息;

代码案例:

img = cv2.imread('1.jpg')
result = cv2.Canny(img, 100, 200)

cv2.imshow('org', img)
cv2.imshow('result', result)
cv2.waitKey(0)

Python OpenCV学习之图像滤波详解

来源:https://blog.csdn.net/weixin_40620310/article/details/122351049

标签:Python,OpenCV,图像滤波
0
投稿

猜你喜欢

  • MySQL Community Server 8.0.11安装配置方法图文教程

    2024-01-26 06:02:45
  • php与javascript正则匹配中文的方法分析

    2024-04-10 14:00:01
  • mysql定时自动备份数据库的方法步骤

    2024-01-15 10:01:19
  • 对Python3之进程池与回调函数的实例详解

    2022-07-30 13:07:01
  • 数据库Sql实现截取时间段和日期实例(SQL时间截取)

    2024-01-27 01:38:29
  • python机器学习之神经网络实现

    2022-01-10 08:10:05
  • 详解Python函数print用法

    2023-06-10 03:47:34
  • pytorch常用函数之torch.randn()解读

    2023-03-24 09:08:29
  • Python制作CSDN免积分下载器

    2021-12-25 03:46:35
  • python3 map函数和filter函数详解

    2023-05-02 02:17:32
  • 在Python开发环境中调用ChatGPT模型详细过程

    2022-03-25 21:59:29
  • 用Dreamweaver MX轻松操作表格

    2009-05-29 18:41:00
  • MySQL数据库优化经验详谈(服务器普通配置)第1/3页

    2024-01-27 23:30:51
  • Pycharm远程连接服务器跑代码的实现

    2021-06-19 21:13:54
  • YUI3设计中的激进和妥协

    2010-01-17 09:59:00
  • python 中 .py文件 转 .pyd文件的操作

    2022-02-17 09:59:38
  • python实现按关键字筛选日志文件

    2022-12-28 21:45:49
  • 史上最全Python文件类型读写库大盘点

    2021-01-28 22:08:26
  • python PaddleSpeech实现婴儿啼哭识别

    2023-08-22 22:25:31
  • js中的window.open返回object的错误的解决方法

    2024-04-17 09:52:27
  • asp之家 网络编程 m.aspxhome.com