opencv Sobel算子提取图形中的轮廓

话不多说先上结果图:

上代码:

// opencv0018.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <opencv2/opencv.hpp>
#include <iostream>

using namespace std;
using namespace cv;

int main()
{
	Mat src, dst;
	src = imread("D:/images/pkq.jpg"); //加载图像
	if (src.empty())
	{
		printf("could not load image...\n");
		return -1;
	}
	char INPUT_TITLE[] = "input image";
	char OUTPUT_TITLE[] = "sobel-demo";
	namedWindow(INPUT_TITLE, CV_WINDOW_AUTOSIZE);
	namedWindow(OUTPUT_TITLE, CV_WINDOW_AUTOSIZE);
	imshow(INPUT_TITLE, src);

	Mat gray_src;
	GaussianBlur(src, dst, Size(3, 3), 0, 0);
	cvtColor(dst, gray_src, CV_BGR2GRAY);
	imshow("gray image", gray_src);

	Mat xgrad, ygrad;
	//Scharr(gray_src, xgrad, CV_16S, 1, 0);
	//Scharr(gray_src, ygrad, CV_16S, 0, 1);

	Sobel(gray_src, xgrad, CV_16S, 1, 0, 3);
	Sobel(gray_src, ygrad, CV_16S, 0, 1, 3);

	convertScaleAbs(xgrad, xgrad);
	convertScaleAbs(ygrad, ygrad);

	imshow("xgrad", xgrad);
	imshow("ygrad", ygrad);

	Mat xygrad = Mat(xgrad.size(), xgrad.type());
	addWeighted(xgrad, 0.5, ygrad, 0.5, 0, xygrad);
	imshow(OUTPUT_TITLE, xygrad);
	waitKey(0);

    return 0;
}

 理论知识:

Sobel 操作

  1. Sobel运算符是一个离散差分运算符。它计算图像强度函数的梯度的近似值。
  2. Sobel算子结合高斯平滑和微分。

公式 

水平变化:这是通过卷积计算与内核具有奇数大小。例如,对于内核大小为3,将计算为

垂直变化:这是通过卷积计算与内核具有奇数大小。例如,对于内核大小为3,将计算为

最终的结果:

喜欢的同学可以一起来学习偶,关注我。收藏,一起过关。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值