边缘检测(Canny算子)实现原理

点击上方“小白学视觉”,选择加"星标"或“置顶”
重磅干货,第一时间送达

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

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

边缘检测有什么作用?

832cfd32f5f565c5f2bc1f2a393917e0.png

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

Canny算子简介

d62572d14c60f90d0bfa853d1e6075f1.png

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

最优边缘检测的特征:

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

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

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

Canny算子边缘检测流程

3718c7bf610604f3719d2ac4a28e0a7c.png

a08e3de6d0ee0e06448091cfa1c58dbe.png

01 转换灰度

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

3b36b482fc9ef229da334898d09965bd.png

02 滤波降噪处理

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

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

0da6367d89ba2ebf3a3bc8cb2bf4a0f8.png

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

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

03 差分计算幅值和方向

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

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

【Y方向】 

a2edaac81840e6bd138f93c28320abf5.png

【X方向】

6cc59dbce6cc0d71100423eb2056927a.png

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

4ac38434c01c8572a69ac7763be48ff8.png

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

【Y方向梯度】

84fe53f7493451e7aad0cc4c15b7c61e.png

【X方向梯度】

c43c0f3e41b0c07202d4c8b79e490e15.png

【此处C点的梯度幅值】

180630475cd813c98e3047e3f5360045.png

【此处C点的梯度方向】

b366b999bf9916b826c2bca34c32bd48.png

04 非极大值抑制

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

非极大值抑制两个特点:

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

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

举例如下图所示

32a105721a6d4969f9ef615e8057dbce.png

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

ab0d27048a18b152e9ca5afa6964d3ea.png

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

df0bfff45d94fcd9c38dab4ca66d2b95.png

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

9d06bf7987fbcd7b9732e1b0d72f67c6.png

每个点的梯度矩阵

043243330f8705334613a78636280934.png

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

277673a03900c55a78579e6d042b4ac3.png

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

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

05 滞后阈值

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

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

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

 
 

声明:部分内容来源于网络,仅供读者学习、交流之目的。文章版权归原作者所有。如有不妥,请联系删除。

下载1:OpenCV-Contrib扩展模块中文版教程

在「小白学视觉」公众号后台回复:扩展模块中文教程,即可下载全网第一份OpenCV扩展模块教程中文版,涵盖扩展模块安装、SFM算法、立体视觉、目标跟踪、生物视觉、超分辨率处理等二十多章内容。


下载2:Python视觉实战项目52讲
在「小白学视觉」公众号后台回复:Python视觉实战项目,即可下载包括图像分割、口罩检测、车道线检测、车辆计数、添加眼线、车牌识别、字符识别、情绪检测、文本内容提取、面部识别等31个视觉实战项目,助力快速学校计算机视觉。


下载3:OpenCV实战项目20讲
在「小白学视觉」公众号后台回复:OpenCV实战项目20讲,即可下载含有20个基于OpenCV实现20个实战项目,实现OpenCV学习进阶。


交流群

欢迎加入公众号读者群一起和同行交流,目前有SLAM、三维视觉、传感器、自动驾驶、计算摄影、检测、分割、识别、医学影像、GAN、算法竞赛等微信群(以后会逐渐细分),请扫描下面微信号加群,备注:”昵称+学校/公司+研究方向“,例如:”张三 + 上海交大 + 视觉SLAM“。请按照格式备注,否则不予通过。添加成功后会根据研究方向邀请进入相关微信群。请勿在群内发送广告,否则会请出群,谢谢理解~
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Sobel算子是一种常用的边缘检测算子,它是一种离散的微分算子,用来检测图像的一阶导数。它基于图像中灰度值的变化来检测边缘。 Sobel算子是一个3x3的矩阵,它有两个方向,一个是水平方向,另一个是垂直方向。对于图像I,水平方向的Sobel算子可以表示为: Gx = [ -1 0 1 -2 0 2 -1 0 1 ] 垂直方向的Sobel算子可以表示为: Gy = [ -1 -2 -1 0 0 0 1 2 1 ] Sobel算子原理是通过对图像进行卷积操作,将图像中每个像素的灰度值与Sobel算子的矩阵进行乘积和求和,得到该像素的梯度大小和方向,从而检测出图像中的边缘Canny算子也是一种常用的边缘检测算子,它是一种基于梯度的算法,用来寻找图像中的边缘Canny算子的主要思想是把图像中的边缘看作是灰度值变化最大的区域,然后通过一系列的步骤来检测这些边缘Canny算子的步骤如下: 1. 对图像进行高斯滤波,以减少噪声的影响。 2. 计算图像中每个像素的梯度大小和方向。 3. 对梯度大小进行非极大值抑制,以保留梯度变化最大的像素。 4. 对保留的像素进行双阈值处理,把像素分为强边缘、弱边缘和非边缘三类。 5. 对弱边缘进行连接,将它们与强边缘连接起来,得到最终的边缘图像。 Canny算子的优点是能够检测出细节较为清晰的边缘,但其缺点是计算量较大,需要进行多次计算和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值