canny算子_边缘检测 Sobel算子

边缘检测是图像处理和计算机视觉中的基本问题,边缘检测的目的是标识数字图像中亮度变化明显的点。图像属性中的显著变化通常反映了属性的重要事件和变化。 这些包括(i)深度上的不连续、(ii)表面方向不连续、(iii)物质属性变化和(iv)场景照明变化。 边缘检测是图像处理和计算机视觉中,尤其是特征提取中的一个研究领域。

根据边缘形成的不同原因,对图像的各像素点进行求微分或者二阶微分可以检测出变化明显的点。边缘检测大大减少了源图像的数据量,剔除了与目标不相干的信息,保留了图像重要的结构属性。边缘检测算子利用图像边缘的突变性质来检测边缘的。可分为以下三种情况:

1.一阶微分为基础的边缘检测,如Sobel算子,Prewitt算子,Roberts算子以及差分边缘检测

2.二阶微分为基础的边缘检测,如Canny算子,laplacian算子

3.混合一阶和二阶的边缘检测,综合利用一阶与二阶微分

首先了解一下什么是非极大值抑制:

非极大值抑制是为了去除伪边缘信息,其原理是通过像素邻域的局部最优值,将非极大值点对于的灰度值作为背景像素点,对其余非极大值的相关信息进行抑制。

了解完什么是非极大值抑制之后,我们看一下sobel算子,sobel算子是广泛应用的微分算子之一,可以计算图像处理中的边缘检测,计算图像的灰度地图。原理就是基于图像的卷积来实现在水平方向与垂直方向检测对于方向上的边缘。对于源图像与奇数Sobel水平核Gx,竖直核Gy进行卷积可计算水平核竖直变换,当内核大小为3x3时:

1c8cd8a03ce432ef9254200ed364b35b.png

对图像中每一点结合卷积后的结果求出近似梯度幅度G:

19a1da07e6b89a6b96d233573cb644af.png

当对精度的要求较高时可以使用Scharr滤波器,Scharr滤波器的水平方向与竖直方向的核为:

078c1169d289b9d348d9d919118b82d8.png

使用OpenCV中的库函数Sobel函数实现边缘检测,OpenCV中的Soble函数原型如下:

void 

参数说明:

src : 输入图像

dst : 和输入图像有相同大小和通道的目标图像

ddepth : 输出图像的深度

dx : x方向的微分阶数

dy : y方向的微分阶数

ksize : sobel算子卷积核的大小,可以为1,3,5,7

scale: 可选参数,缩放导数的放缩因子

delta: 可选的增量常数

borderType : 用于推断图像外部像素的边界模式,一般是DORDER_DEFAULT,不支持BORDER_WRAP.

代码示例如下:

#include 

结果展示如下:

aff4eb31ec9d46834a58e04b6f15eeba.png

2dfa4736206086b168088cb2b7dd2555.png

e17d264329e7e6277c2bf0b12841b420.png
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCV是一款流行的计算机视觉库,其中包含了许多图像处理算法。其中,sobelcanny算子是两种常用的边缘检测算法Sobel算子是一种基于梯度的边缘检测算法,其通过对图像进行卷积操作来检测图像中的边缘。在OpenCV中,可以使用cv2.Sobel()函数来实现Sobel算子边缘检测。下面是一个示例代码: ``` import cv2 # 读取图像 img = cv2.imread('test.jpg', 0) # 对图像进行Sobel边缘检测 sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=5) sobely = cv2.Sobel(img, cv2.CV_64F, 0, 1, ksize=5) sobel = cv2.addWeighted(sobelx, 0.5, sobely, 0.5, 0) # 显示结果 cv2.imshow('Sobel', sobel) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在上面的代码中,cv2.Sobel()函数的第一个参数是输入图像,第二个参数是输出图像的数据类型,第三个和第四个参数是对应于x和y方向的求导阶数,最后一个参数是卷积大小Canny算子是另一种常用的边缘检测算法,其通过计算图像中像素点的灰度梯度和非极大值抑制来检测边缘。在OpenCV中,可以使用cv2.Canny()函数来实现Canny算子边缘检测。下面是一个示例代码: ``` import cv2 # 读取图像 img = cv2.imread('test.jpg', 0) # 对图像进行Canny边缘检测 edges = cv2.Canny(img, 100, 200) # 显示结果 cv2.imshow('Canny', edges) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在上面的代码中,cv2.Canny()函数的第一个参数是输入图像,第二个和第三个参数是Canny算子的阈值,用于控制边缘的检测程度。 总的来说,OpenCV提供了简单易用的sobelcanny算子,用于处理图像边缘检测问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值