我是靠谱客的博主 可爱大侠,这篇文章主要介绍OpenCV边缘检测:Canny算子,Sobel算子,Laplace算子,Scharr滤波器,现在分享给大家,希望可以做个参考。

Canny算法检测边缘步骤:

1.消除噪声。 一般情况下,使用高斯平滑滤波器卷积降噪。 如下显示了一个 size = 5 的高斯内核示例:




 

2.计算梯度幅值和方向。 此处,按照Sobel滤波器的步骤。

 

Ⅰ.运用一对卷积阵列 (分别作用于 x 和 y 方向):


 



Ⅱ.使用下列公式计算梯度幅值和方向:



 

梯度方向近似到四个可能角度之一(一般为0, 45, 90, 135)

 

3.非极大值抑制。 这一步排除非边缘像素, 仅仅保留了一些细线条(候选边缘)。


 

4.滞后阈值。最后一步,Canny 使用了滞后阈值,滞后阈值需要两个阈值(高阈值和低阈值):

 

Ⅰ.如果某一像素位置的幅值超过 高 阈值, 该像素被保留为边缘像素。

Ⅱ.如果某一像素位置的幅值小于 低 阈值, 该像素被排除。

.如果某一像素位置的幅值在两个阈值之间,该像素仅仅在连接到一个高于 高 阈值的像素时被保留。


tips:对于Canny函数的使用,推荐的高低阈值比在2:1到3:1之间。


Canny函数:

复制代码
1
C++: void Canny(InputArray image,OutputArray edges, double threshold1, double threshold2, int apertureSize=3,bool L2gradient=false )

  • 第三个参数,double类型的threshold1,第一个滞后性阈值。
  • 第四个参数,double类型的threshold2,第二个滞后性阈值。
  • 第五个参数,int类型的apertureSize,表示应用Sobel算子的孔径大小,其有默认值3

代码:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include<opencv2/opencv.hpp> #include<opencv2/highgui/highgui.hpp> #include<iostream> using namespace std; using namespace cv; int main() { Mat img; img=imread("C://Users//huashuo111//Desktop//橘子.jpg"); namedWindow("原图",1); imshow("原图",img); Mat img1;//直接利用Canny算子 Canny(img,img1,3,9,3); imshow("边缘",img1); Mat img2,gray,dst; dst.create(img.size(),img.type()); dst=Scalar::all(0); img2=img.clone(); cvtColor(img2,gray,CV_BGR2GRAY);//灰度图 blur(gray,gray,Size(3,3));//均值模糊 Canny(gray,gray,3,9,3);//Canny检测 img2.copyTo(dst,gray);//Canny检测后边缘图做掩码,加到原图上,呈现彩色边缘 imshow("边缘1",dst); imwrite("C://Users//huashuo111//Desktop//边缘.jpg",img1); imwrite("C://Users//huashuo111//Desktop//边缘1.jpg",dst); waitKey(); return 0; }

原图:


直接Canny检测:



图像增强后检测:




最后

以上就是可爱大侠最近收集整理的关于OpenCV边缘检测:Canny算子,Sobel算子,Laplace算子,Scharr滤波器的全部内容,更多相关OpenCV边缘检测:Canny算子内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(87)

评论列表共有 0 条评论

立即
投稿
返回
顶部