opencv3.1学习笔记(18) Laplance算子


演示代码:

#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>

using namespace cv;

int main(int argc, char** argv) {
	Mat src, dst;
	src = imread("e:/girl.png");
	
	Mat gray,dst2;
	GaussianBlur(src, dst, Size(3, 3), 0, 0);
	cvtColor(dst, gray, CV_BGR2GRAY);

	Laplacian(gray, dst2, CV_16S, 3);
	convertScaleAbs(dst2, dst2);

	threshold(dst2, dst2, 0, 255, THRESH_OTSU | THRESH_BINARY);
	imshow("Laplacian",dst2);

	waitKey(0);
	return 0;
}



image.png

(Laplaciant算子的直接结果,有一定的噪点,所以后面可以加上Threshold来去噪点)

image.png

(Laplaciant算子,加上Threshold后的效果)



代码解释:

理论

image.png

解释:在二阶导数的时候,最大变化处的值为零即边缘是零值。通过二阶

导数计算,依据此理论我们可以计算图像二阶导数,提取边缘。


Laplance算子

二阶导数,拉普拉斯算子(Laplance operator)

image.png

Opencv已经提供了相关API - cv::Laplance


处理流程

  • 高斯模糊 – 去噪声GaussianBlur()

  • 转换为灰度图像cvtColor()

  • 拉普拉斯 – 二阶导数计算Laplacian()

  • 取绝对值convertScaleAbs()

  • 显示结果


API使用cv::Laplacian

Laplacian(
InputArray src,
OutputArray dst,
int depth, //深度CV_16S
int kisze, // 3
double scale = 1,
double delta =0.0,
int borderType = 4
)


--------------------- 

作者:hackpig

来源:www.skcircle.com

版权声明:本文章代码及资料部分或全部来自贾志刚老师的视频,勇哥只是在个人理解的基础上做学习笔记,转载请附上博文链接!


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864