图像处理——基于OpenCV的Scharr边缘检测

前言

Scarry是sobel算子的特殊改进情况。当内核大小为3时,Sobel内核可能产生比较明显的误差,为了解决这一问题,Opencv提供了Scharr函数,但该函数仅作用于大小为3的内核,运行速度与Sobel函数一样,但结果却更加精确。 Scharr滤波器运算符计算x或y方向的图像差分。其实它的参数变量和Sobel基本上是一样的,只是有ksize核的大小。

Scharr算子

1.OpenCV C++ API

void Scharr(InputArray src, OutputArray dst,int ddepth ,int dx, int dy,double scale = 1,double delta = 0,int borderType=BORDER_DEFAULT)

InputArray src:输入图像。
OutputArray dst:输出图像。
int ddepth:输出图像深度。
int dx:x方向上的差分阶数。
int dy:y方向上的差分阶数。
double scale :计算导数值时可选的缩放因子,默认值1,表示默认情况下没用应用缩放。
double delta:表示在结果存入输出图像之前可选的delta值,默认值0。
int borderType:边界模式。

2.代码示例

#include <opencv2/opencv.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
void scharrEdge(cv::Mat &src, cv::Mat &dst);
int main()
{
	cv::Mat src = cv::imread("2.jpg");

	if (src.empty())
	{
		
		return -1;
	}
	cv::namedWindow("原图",0);
	cv::imshow("原图", src);

	cv::Mat dst =cv::Mat(src.size(), src.type());
	cv::Mat gray;
	//灰度图像
	cvtColor(src, gray, cv::COLOR_BGR2GRAY);
	scharrEdge(gray, dst);
	cv::namedWindow("Scharr", 0);
	cv::imshow("Scharr", dst);
	
	cv::waitKey(0);
	return 0;
}

void scharrEdge(cv::Mat &src,cv::Mat &dst)
{
	cv::Mat scharr_x, scharr_y;
	//求x方向的梯度
	cv::Scharr(src, scharr_x, CV_16S, 1, 0, 1, 0, cv::BORDER_DEFAULT);
	cv::convertScaleAbs(scharr_x, scharr_x);

	//求y方向的梯度
	cv::Scharr(src, scharr_y, CV_16S, 0, 1, 1, 0, cv::BORDER_DEFAULT);
	cv::convertScaleAbs(scharr_y, scharr_y);
	//合并梯度
	cv::addWeighted(scharr_x, 0.5, scharr_y, 0.5, 0, dst);
}

3.运行结果
在这里插入图片描述
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知来者逆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值