0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

关于边缘检测算子的实现原理

新机器视觉 来源:新机器视觉 2023-01-05 11:41 次阅读

当前,边缘检测算法在实际应用中越加广泛,技术趋势也是快速发展,热火朝天。很多朋友或多或少了解,需要实现各类功能,尤其是一些复杂的需求,实现更好的滤波、满足更佳的提取效果,一时半会儿无从下手。

下面小编就带大家了解关于边缘检测算子的实现原理。由于边缘检测算子常用方法较多(Sobel算子,Kirsch算子,Laplacian算子,Canny算子等),在此以Canny算子为例,带大家了解简单的实现原理。

边缘检测有什么作用?

简单通俗讲,边缘检测主要应用于一些数据信息的处理,提取想要的目标,剔除一些不相关的干扰及无用信息,通过更少的数据信息量获取更多关注的信息。

Canny算子简介

Canny 边缘检测算法 是 John F. Canny 于 1986年开发出来的一个多级边缘检测算法,此算法被很多人认为是边缘检测的最优算法,相对其他边缘检测算法来说其识别图像边缘的准确度要高很多。

最优边缘检测的特征:

低错误率: 标识出尽可能多的实际边缘,同时尽可能的减少噪声产生的误报

高定位性: 标识出的边缘要与图像中的实际边缘尽可能接近

最小响应: 图像中的边缘只能标识一次

Canny算子边缘检测流程

1223f54a-852f-11ed-bfe3-dac502259ad0.png

01 转换灰度

鉴于Canny算子只能对单通道灰度图像进行处理,因此在进行边缘检测之前需要将原图像进行灰度转换,以OpenCV为例,使用其封装的函数实现彩色到灰度的转换。

12483aa4-852f-11ed-bfe3-dac502259ad0.png

02 滤波降噪处理

完美的图像信息是无噪声的,图像质量很好,但是现实中由于采集设备、环境干扰等多方面的原因导致采集到的图像信息都是含有大量噪声信息的,这些噪声最常见的就是椒盐噪声和高斯噪声。

Canny算子是一种综合在抗噪声干扰和精确定位之间寻求最佳折中方案的边缘检测方法,一般使用高斯滤波来去除噪声,下面是常见的3X3的卷积核模板:

127177ca-852f-11ed-bfe3-dac502259ad0.png

高斯滤波可以将图像中的噪声部分过滤出来,避免后面进行边缘检测时将错误的噪声信息也误识别为边缘了。

滤波核的维数不应选的过大,否则可能会将边缘信息给平滑掉,使得边缘检测算子无法正确识别边缘信息。

03 差分计算幅值和方向

使用一阶有限差分计算梯度可以得到图像在x和y方向上偏导数的两个矩阵,Canny算子中使用的是 Sobel 算子作为梯度算子,当然还可以自己构造其它的如:Roberts算子、Prewitt算子等一阶边缘检测算子来作为梯度算子。

下面以Sobel算子为例来计算梯度的幅值和方向:

【Y方向】

12848efa-852f-11ed-bfe3-dac502259ad0.png

【X方向】

129d4ba2-852f-11ed-bfe3-dac502259ad0.png

预设H(i , j)为计算的图像

12be0932-852f-11ed-bfe3-dac502259ad0.png

其中点C ( i , j ) 是要计算的梯度

【Y方向梯度】

12d1ee0c-852f-11ed-bfe3-dac502259ad0.png

【X方向梯度】

12f1275e-852f-11ed-bfe3-dac502259ad0.png

【此处C点的梯度幅值】

13094ef6-852f-11ed-bfe3-dac502259ad0.png

【此处C点的梯度方向】

1323f418-852f-11ed-bfe3-dac502259ad0.png

04 非极大值抑制

对非极大值的数据进行抑制,也可以理解成对非极大值数据排除其是边缘的可能性。8邻域内图像梯度幅值矩阵中的元素值越大,说明图像中该点的梯度值越大,再结合检测点的梯度方向,就可以定位出大概的边缘信息。

非极大值抑制两个特点:

当前位置的梯度值与梯度方向上两侧的梯度值比较

梯度方向是垂直于边缘方向

举例如下图所示

1338625e-852f-11ed-bfe3-dac502259ad0.png

每个点的X方向和Y方向梯度方向矩阵

1350cf60-852f-11ed-bfe3-dac502259ad0.png

每个点的梯度方向的梯度角矩阵

1370efb6-852f-11ed-bfe3-dac502259ad0.png

Canny算子将Gy/Gx的值求绝对值,OpenCV中的梯度角矩阵

138c8e6a-852f-11ed-bfe3-dac502259ad0.png

每个点的梯度矩阵

13ab1ace-852f-11ed-bfe3-dac502259ad0.png

综上所示,计算出来的梯度值、梯度方向可以大致判断出此 8 邻域内的值的边缘信息如下图

13c7bb52-852f-11ed-bfe3-dac502259ad0.png

梯度方向是同时包含多个梯度值的,因此需要将梯度方向两边的梯度值进行线性插值,插值系数β有如下要求:越靠近梯度方向的梯度值,其所占比例越大。

完成非极大值抑制后,会得到一个二值图像,非边缘的点灰度值均为0,可能为边缘的点灰度值为255。这样的一个检测结果还是包含了很多由噪声及其他原因造成的假边缘,还需要双阈值筛选处理。

05 滞后阈值

使用双阈值来对二值化图像进行筛选,通过选取合适的大阈值与小阈值可以得出最为接近图像真实边缘的边缘图像。

具体实现方法为:根据高阈值得到一个边缘图像,这样一个图像含有很少的假边缘,但是由于阈值较高,产生的图像边缘可能不闭合,解决该问题就采用了另外一个低阈值。

在高阈值图像中把边缘链接成轮廓,当到达轮廓的端点时,该算法会在断点的8邻域点中寻找满足低阈值的点,再根据此点收集新的边缘,直到整个图像边缘闭合。

编辑:黄飞

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 高斯滤波
    +关注

    关注

    0

    文章

    12

    浏览量

    8040
  • 边缘检测
    +关注

    关注

    0

    文章

    91

    浏览量

    18105
  • Canny
    +关注

    关注

    0

    文章

    14

    浏览量

    9677

原文标题:边缘检测(Canny算子)实现原理

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    基于Canny边缘检测算子的图像检索算法

    【摘要】:针对依赖传统Canny算子的基于边缘的图像检索系统所存在的不足,提出一种基于Canny边缘检测的图像检索算法。使用改进的Canny算子
    发表于 04-24 10:03

    【Banana Pi M1+申请】阈值自适应视频边缘检测算法的嵌入式快速实现

    申请理由:本人已经成功完成阈值自适应视频边缘检测算法的FPGA快速实现,但FPGA也有很多局限性,所以想将硬件平台从FPGA换成香蕉派。相信会有全新的体验,和更加快捷的开发途径。项目描述:在香蕉派上
    发表于 06-20 15:55

    关于canny算子边缘检测的问题

    本帖最后由 豆吖豆 于 2017-4-4 23:14 编辑 grd=edge(Egray,'canny',0.09,'both');大神门 问一下这个后面的0.09和both什么意思是指的是Egray图像的上下大小还是,另外可以的话能大概说说这个canny边缘检测算
    发表于 04-04 22:27

    基于Qualcomm FastCv的边缘检测算法详解

    ,而没有必要指出边缘的精确位置。2.微分边缘检测算子2.1.一阶微分算子2.1.1Roberts 算子 Roberts
    发表于 09-21 11:45

    基于视觉图像的微小零件边缘检测算法研究

    因子。Sobel算子边缘检测算子,故其处理模板中各因子之和为零。另一方面,由于正因子和负因子之和分别为4和一4,在极端情况下处理结果可能溢出。因此,在实际使用时,Sobel算子通常采
    发表于 11-15 16:23

    边缘检测算法分为哪几种?它们有何不同?

    边缘检测是什么?边缘检测算子有哪些?边缘检测算法分为哪几种?它们有何不同?
    发表于 05-31 06:57

    边缘检测的几种微分算子

    一、边缘检测边缘检测的几种微分算子:一阶微分算子:Roberts、Sobel、Prewitt二阶
    发表于 07-26 08:29

    基于形态灰度边缘检测算法的一种改进

    使用形态学的思想进行图像的边缘检测,提出了在一次形态处理中使用双结构元的一系列一般性形态边缘检测算子和抗噪型形态边缘
    发表于 04-19 19:26 32次下载

    基于Canny边缘检测算子的图像检索算法

      针对依赖传统Canny算子的基于边缘的图像检索系统所存在的不足,提出一种基于Canny边缘检测的图像检索算法。使用改进的Canny算子
    发表于 02-11 11:22 28次下载

    基于高斯滤波与矢量微分算子的小波多尺度边缘检测算

    基于高斯滤波与矢量微分算子的小波多尺度边缘检测算法 摘 要: 采用一种基于高斯滤波与矢量微分算子相结合的近似小波多尺度边缘算法. 该算法分
    发表于 04-23 14:58 17次下载

    基于改进的Laplacian算子图像边缘检测

    分析了图像边缘特性以及Laplacian算子检测图像边缘的基本原理!并对经典Laplacian算子进行改进! 提出了一种新的
    发表于 05-17 10:46 29次下载
    基于改进的Laplacian<b class='flag-5'>算子</b>图像<b class='flag-5'>边缘</b><b class='flag-5'>检测</b>

    内积能量与边缘检测

    本文提出了一种新型的边缘检测算子--基于内积能量与边缘检测算子。在基于内积能量的边缘检测算自重,
    发表于 05-19 15:47 27次下载

    边缘检测算子在汽车牌照区域检测中的应用

    文中介绍了常用的几种 边缘检测 算子,不同的微分算子对不同边缘检测的敏感程度是不同的,因此对不同
    发表于 07-25 16:13 22次下载
    <b class='flag-5'>边缘</b><b class='flag-5'>检测算子</b>在汽车牌照区域<b class='flag-5'>检测</b>中的应用

    Robinson边缘检测算

    传统的Canny边缘检测算子是一种含有最优化思想的算子,它具有较高的检测精度,可以达到单像素级,但是因为它本身对噪声比较敏感,所以需要先利用Gauss滤波、均值滤波、中值滤波等滤波器进
    发表于 12-01 14:13 0次下载

    图像处理边缘检测算子分类

    边缘检测类似微分处理,它检测的变化的部分,必然对噪声和图像的亮度变化都有相应处理。因此,把均值处理加入到边缘检测过程中一定要非常谨慎。我们可
    的头像 发表于 08-17 15:54 7582次阅读