我是靠谱客的博主 可爱大侠,最近开发中收集的这篇文章主要介绍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函数:

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

代码:

#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算子,Sobel算子,Laplace算子,Scharr滤波器所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部