1.Laplacian算子

拉普拉斯(Laplacian)算子是n维欧几里德空间中的一个二阶微分算子,常用于图像增强领域和边缘提取。它通过灰度差分计算邻域内的像素,基本流程是:判断图像中心像素灰度值与它周围其他像素的灰度值,如果中心像素的灰度更高,则提升中心像素的灰度;反之降低中心像素的灰度,从而实现图像锐化操作。在算法实现过程中,Laplacian算子通过对邻域中心像素的四方向或八方向求梯度,再将梯度相加起来判断中心像素灰度与邻域内其他像素灰度的关系,最后通过梯度运算的结果对像素灰度进行调整。Laplacian算子分为四邻域和八邻域,四邻域是对邻域中心像素的四方向求梯度,八邻域是对八方向求梯度。

kernel=np.array([[0,1,0],[1,-4,1],[0,1,0]],dtype=int)

在python中使用Laplacian() 函数实现,其函数用法如下:

dst = Laplacian(src, ddepth[, dst[, ksize[, scale[, delta[, borderType]]]]])

1.src 表示输入图像;

2.dst 表示输出的边缘图,其大小和通道数与输入图像相同;

3.ddepth 表示目标图像所需的深度;

4.ksize 表示用于计算二阶导数的滤波器的孔径大小,其值必须是正数和奇数,且默认值为1;

5.scale 表示计算拉普拉斯算子值的可选比例因子。默认值为1;

6.delta 表示将结果存入目标图像之前,添加到结果中的可选增量值,默认值为0;

7.borderType 表示边框模式。

注:在进行Laplacian算子处理之后,还需要调用 convertScaleAbs() 函数计算绝对值,并将图像转换为8位图进行显示。其函数用法如下:

dst = convertScaleAbs(src[, dst[, alpha[, beta]]])

1.src 表示原数组;

2.dst 表示输出数组,深度为8位;

3.alpha 表示比例因子;

4.beta 表示原数组元素按比例缩放后添加的值。

当ksize=1时,Laplacian() 函数采用 33 的孔径 (四邻域模板) 进行变换处理。代码如下所示:

2. Roberts算子

Roberts算子又称为交叉微分算法,它是基于交叉差分的梯度算法,通过局部差分计算检测边缘线条。常用来处理具有陡峭的低噪声图像,当图像边缘接近于正45度或负45度时,该算法处理效果更理想。其缺点是对边缘的定位不太准确,提取的边缘线条较粗。

kernelx = np.array([[-1,0],[0,1]], dtype=int)

kernely = np.array([[0,-1],[1,0]], dtype=int)

在Python中,Roberts算子主要通过numpy定义模板,再调用OpenCV的 filter2D() 函数实现边缘提取。该函数主要是利用内核实现对图像的卷积运算。filter2D() 函数用法如下所示:

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

1.src 表示输入图像;

2.dst 表示输出的边缘图,其大小和通道数与输入图像相同;

3.ddepth 表示目标图像所需的深度;

4.kernel 表示卷积核,一个单通道浮点型矩阵;

5.anchor 表示内核的基准点,其默认值为 (-1,-1),位于中心位置;

6.delta 表示在储存目标图像前可选的添加到像素的值,默认值为0;

7.borderType 表示边框模式。

代码如下所示:

3. Prewitt算子

Prewitt算子是一种图像边缘检测的微分算子,其原理是利用特定区域内像素灰度值产生的差分实现边缘检测。由于Prewitt算子采用3x3模板对区域内的像素值进行计算,而Robert算子的模板为2x2,故Prewitt算子的边缘检测结果在水平方向和垂直方向均比Robert算子更加明显。Prewitt算子适合用来识别噪声较多、灰度渐变的图像。

kernelx = np.array([[1, 1, 1], [0, 0, 0], [-1, -1, -1]], dtype=int)

kernely = np.array([[-1, 0, 1], [-1, 0, 1], [-1, 0, 1]], dtype=int)

在Python中,Prewitt算子的实现过程与Roberts算子比较相似。通过Numpy定义模板,再调用OpenCV的filter2D() 函数实现对图像的卷积运算,最终通过 convertScaleAbs() 和 addWeighted() 函数实现边缘提取。

代码如下所示:

4.Sobel算子

Sobel算子是一种用于边缘检测的离散微分算子,它结合了高斯平滑和微分求导。该算子用于计算图像明暗程度近似值,根据图像边缘旁边明暗程度把该区域内超过某个数的特定点记为边缘。Sobel算子在Prewitt算子的基础上增加了权重的概念,认为相邻点的距离远近对当前像素点的影响是不同的,距离越近的像素点对应当前像素的影响越大,从而实现图像锐化并突出边缘轮廓。Sobel算子的边缘定位更准确,常用于噪声较多、灰度渐变的图像。

kernelx = np.array([[1, 0, -1], [2, 0, -2], [1, 0, -1]], dtype=int)

kernely = np.array([[-1, -2, -1], [0, 0, 0], [1,2, 1]], dtype=int)

Sobel算子根据像素点上下、左右邻点灰度加权差,在边缘处达到极值这一现象检测边缘。对噪声具有平滑作用,提供较为精确的边缘方向信息。因为Sobel算子结合了高斯平滑和微分求导(分化),因此结果会具有更多的抗噪性,当对精度要求不是很高时,Sobel算子是一种较为常用的边缘检测方法。

在python中使用Sobel()函数实现,其函数用法如下:

dst = Sobel(src, ddepth, dx, dy[, dst[, ksize[, scale[, delta[, borderType]]]]])

1.src 表示输入图像;

2.dst 表示输出的边缘图,其大小和通道数与输入图像相同;

3.ddepth 表示目标图像所需的深度,针对不同的输入图像,输出目标图像有不同的深度;

4.dx 表示 x方向上的差分阶数,取值1或 0;

5.dy 表示 y方向上的差分阶数,取值1或0;

6.ksize 表示Sobel算子的大小,其值必须是正数和奇数;

7.scale 表示缩放导数的比例常数,默认情况下没有伸缩系数;

8.delta 表示将结果存入目标图像之前,添加到结果中的可选增量值;

9.borderType 表示边框模式。

注:在进行Sobel算子处理之后,还需要调用 convertScaleAbs() 函数计算绝对值,并将图像转换为8位图进行显示。
代码如下:

5.平滑滤波器

除了以上4种锐化滤波算子,在这里还简单提一下平滑滤波器。主要是高斯滤波器和中值滤波器。代码如下所示:

6.总结

Laplacian算子对噪声比较敏感,由于其算法可能会出现双像素边界,常用来判断边缘像素位于图像的明区或暗区,很少用于边缘检测;

Robert算子对陡峭的低噪声图像效果较好,尤其是边缘正负45度较多的图像,但定位准确率较差;

Prewitt算子对灰度渐变的图像边缘提取效果较好,而没有考虑相邻点的距离远近对当前像素点的影响;

Sobel算子考虑了综合因素,对噪声较多的图像处理效果更好。

边缘检测算法主要是基于图像强度的一阶导数二阶导数,但导数通常对噪声很敏感,因此需要采用滤波器来过滤噪声,并调用图像增强或阈值化算法进行处理,最后再进行边缘检测。例如:可以采用高斯滤波去噪和阈值化处理之后,再进行边缘检测 。

python数字图像处理——边缘检测算子(Laplacian算子、Roberts算子、Prewitt算子和Sobel算子)相关推荐

  1. 边缘提取——Prewitt算子和Sobel算子

    目录 Prewitt算子和Sobel算子 理论介绍 编码实现(Python) debug过程 Prewitt算子和Sobel算子 理论介绍 Prewitt算子和Sobel算子也是基于一阶导数的算子. ...

  2. 图像处理——Canny算子 图像边缘检测:Canny算子、Prewitt算子和sobel算子

    https://blog.csdn.net/fengye2two/article/details/79190759 https://www.jianshu.com/p/bed4ffe996a1

  3. python高斯滤波和降噪_python添加高斯噪声和椒盐噪声,实现中值滤波和均值滤波,实现Roberts算子和Sobel算子...

    写在前面 HIT大三上学期视听觉信号处理课程中视觉部分的实验一,经过和学长们实验的对比发现每一级实验要求都不一样,因此这里标明了是2019年秋季学期的视觉实验一. 由于时间紧张,代码没有进行任何优化, ...

  4. 图像的常规边缘检测(梯度算子、Roberts算子和Sobel算子)之c++实现(qt + 不调包)

    1.基本原理 边缘检测一般是利用微分等方法,通过对灰度跃变的分析寻找图像上区域边缘的技术.今天的猪脚是梯度算子和Roberts算子. 1.梯度算子是怎么来的? 答:图像是一个二维集合,在(x, y)处 ...

  5. [Python图像处理] 十八.图像锐化与边缘检测之Scharr算子、Canny算子和LOG算子

    该系列文章是讲解Python OpenCV图像处理知识,前期主要讲解图像入门.OpenCV基础用法,中期讲解图像处理的各种算法,包括图像锐化算子.图像增强技术.图像分割等,后期结合深度学习研究图像识别 ...

  6. 数字图像处理---LOG算子和CANNY算子边缘提取(matlab)

    LOG算子和CANNY算子边缘提取 边缘的含义: 在数字图像中,边缘是指图像局部变化最显著的部分,边缘主要存在于目标与目标,目标与背景之间,是图像局部特性的不连续性,如灰度的突变.纹理结构的突变.颜色 ...

  7. 数字图像处理:边缘检测(Edge detection)

    转载自:https://zhuanlan.zhihu.com/p/59640437 觉得写得通俗易懂,要是每个人的博客都这么人性化.... 写在前面: 本文篇幅较长,用了大量图与公式帮助大家深入理解各 ...

  8. python数字图像处理(17):边缘与轮廓

    在前面的python数字图像处理(10):图像简单滤波 中,我们已经讲解了很多算子用来检测边缘,其中用得最多的canny算子边缘检测. 本篇我们讲解一些其它方法来检测轮廓. 1.查找轮廓(find_c ...

  9. python绘制灰度图片直方图-python数字图像处理实现直方图与均衡化

    在图像处理中,直方图是非常重要,也是非常有用的一个处理要素. 在skimage库中对直方图的处理,是放在exposure这个模块中. 1.计算直方图 函数:skimage.exposure.histo ...

  10. 第1章 Python 数字图像处理(DIP) --绪论

    Python 数字图像处理 关于本专栏 此专栏为 Python 数字图像处理(DIP)(冈萨雷斯版),专栏里文章的内容都是来自书里,全部手打,非OCR,因为很多公式,都是用LaTex输入,力求更好看的 ...

最新文章

  1. kernfs_addrm_start kernfs_add_one
  2. 海康威视摄像头安装插件检测不到_海康威视摄像机常见问题解答
  3. hbase源码系列(一)Balancer 负载均衡
  4. 两个多精度十进制数加法程序设计_初中数学之有理数的加减,学会加法,减法即会,掌握技巧轻松计算...
  5. java的部署目录在哪里_Java:Tomcat的部署实例之资源目录
  6. 【ArcGIS风暴】如何将矢量数据(点、线、面)折点坐标转为GeoJSON格式?
  7. bitcount方法详解_Java Long类的bitCount()方法和示例
  8. 2022年第一个线上问题,被领导骂惨了!
  9. 论信息化投标低于1元中标值吗?
  10. c语言年历表程序设计,c语言程序设计年历显示-20210413153548.docx-原创力文档
  11. 纽交所决定将蛋壳公寓ADS摘牌
  12. 霍夫曼编码实验matlab,哈夫曼编码 MATLAB程序
  13. MySQL5.5编译工具configure向cmake过渡指南
  14. Zookeeper11问
  15. RFC791:INTERNET PROTOCOL网络协议
  16. 存货的三个加权平均单价
  17. OpenCV视频处理操作
  18. 鼠标键盘长时间无动作、电脑空闲超过一定时间自动关机、自动睡眠软件 —— 定时执行专家
  19. cocos2d-x的初步学习七
  20. mysql修改系统日期_修改系统和MySQL时区

热门文章

  1. 找不到该项目,请确认该项目的位置的办法
  2. 托业词汇汇总(修订版)
  3. QTreeView的使用(四)
  4. 多选框的 全选 与 取消全选
  5. 等保2.0二级通用要求
  6. 如何从UCI获取数据集?
  7. matlab光学应用实践,Matlab在光学信息处理仿真实验中的应用
  8. 三维模型转换html,三维模型查看器转换软件FinalMesh Professional 1.2.0.329 Pro | C4DSKY...
  9. 区块链开发之Solidity编程基础(一)
  10. 【SpringCloud】-- SpringCloud简介