• OpenCV函数 Laplacian 实现 Laplacian 算子 的离散模拟。

原理

  1. 前一节我们学习了 Sobel 算子 ,其基础来自于一个事实,即在边缘部分,像素值出现”跳跃“或者较大的变化。如果在此边缘部分求取一阶导数,你会看到极值的出现。正如下图所示:

  2. 如果在边缘部分求二阶导数会出现什么情况?

    你会发现在一阶导数的极值位置,二阶导数为0。所以我们也可以用这个特点来作为检测图像边缘的方法。 但是, 二阶导数的0值不仅仅出现在边缘(它们也可能出现在无意义的位置),但是我们可以过滤掉这些点。

Laplacian 算子

  1. 从以上分析中,我们推论二阶导数可以用来 检测边缘 。 因为图像是 “2维”, 我们需要在两个方向求导。使用Laplacian算子将会使求导过程变得简单。
  2. Laplacian 算子 的定义:

  1. OpenCV函数 Laplacian 实现了Laplacian算子。 实际上,由于 Laplacian使用了图像梯度,它内部调用了 Sobel 算子。

源码

  1. 本程序做什么?

    • 装载图像
    • 使用高斯平滑消除噪声, 将图像转换到灰度空间。
    • 使用Laplacian算子作用于灰度图像,并保存输出图像。
    • 输出结果。
  2. 下面是本教程的源码,你也可以从 这里 下载。
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include <stdlib.h>
#include <stdio.h>using namespace cv;/** @函数 main */
int main( int argc, char** argv )
{Mat src, src_gray, dst;int kernel_size = 3;int scale = 1;int delta = 0;int ddepth = CV_16S;char* window_name = "Laplace Demo";int c;/// 装载图像src = imread( argv[1] );if( !src.data ){ return -1; }/// 使用高斯滤波消除噪声GaussianBlur( src, src, Size(3,3), 0, 0, BORDER_DEFAULT );/// 转换为灰度图cvtColor( src, src_gray, CV_RGB2GRAY );/// 创建显示窗口namedWindow( window_name, CV_WINDOW_AUTOSIZE );/// 使用Laplace函数Mat abs_dst;Laplacian( src_gray, dst, ddepth, kernel_size, scale, delta, BORDER_DEFAULT );convertScaleAbs( dst, abs_dst );/// 显示结果imshow( window_name, abs_dst );waitKey(0);return 0;}

解释

  1. 首先申明变量:

    Mat src, src_gray, dst;
    int kernel_size = 3;
    int scale = 1;
    int delta = 0;
    int ddepth = CV_16S;
    char* window_name = "Laplace Demo";
    

  2. 装载原图像:

    src = imread( argv[1] );if( !src.data ){ return -1; }
    

  3. 高斯平滑降噪:

    GaussianBlur( src, src, Size(3,3), 0, 0, BORDER_DEFAULT );
    

  4. 使用 cvtColor 转换为灰度图

    cvtColor( src, src_gray, CV_RGB2GRAY );
    

#.对灰度图使用Laplacian算子:

Laplacian( src_gray, dst, ddepth, kernel_size, scale, delta, BORDER_DEFAULT );

函数接受了以下参数:

  • src_gray: 输入图像。
  • dst: 输出图像
  • ddepth: 输出图像的深度。 因为输入图像的深度是 CV_8U ,这里我们必须定义 ddepth = CV_16S 以避免外溢。
  • kernel_size: 内部调用的 Sobel算子的内核大小,此例中设置为3。
  • scaledelta 和 BORDER_DEFAULT: 使用默认值。
  1. 将输出图像的深度转化为 CV_8U :

    convertScaleAbs( dst, abs_dst );
    

  2. 显示结果:

    imshow( window_name, abs_dst );
    

结果

#.在编译上面的代码之后, 我们可以运行结果,将图片路径输入,如下图:

  1. 我们得到下图所示的结果。 注意观察树木和牛的轮廓基本上很好的反映出来(除了像素值比较接近的地方, 比如奶牛的头部)。 此外,注意树木(右方)后面的房子屋顶被明显的加强显示出来,这是由于局部对比度比较强的原因。

OpenCV函数 Laplacian 算子实现相关推荐

  1. 学习笔记(12):Python+OpenCV计算机视觉-laplacian算子的使用

    立即学习:https://edu.csdn.net/course/play/10552/234946?utm_source=blogtoedu laplacian(拉普拉斯)算子 dst=cv2.La ...

  2. Python OpenCV -- Laplacian 算子(十)

    Laplacian 算子: 原理分析:  Sobel 算子 : 在一个图像区域中的边缘部分,像素值出现"跳跃"或者较大的变化.如果在此边缘部分求取一阶导数,会看到极值的出现如图: ...

  3. [Python从零到壹] 五十八.图像增强及运算篇之图像锐化Sobel、Laplacian算子实现边缘检测

    欢迎大家来到"Python从零到壹",在这里我将分享约200篇Python系列文章,带大家一起去学习和玩耍,看看Python这个有趣的世界.所有文章都将结合案例.代码和作者的经验讲 ...

  4. OpenCV之拉普拉斯算子:Laplacian()函数

    根据图像处理的原理,二阶导数可以用来进行边缘检测,因为图像是二维的,需要在两个方向上求导,使用Laplacian算子将会使求导过程变得简单. Laplacian算子的定义: 需要说明的是,由于Lapl ...

  5. 【OpenCV 4开发详解】Laplacian算子

    本文首发于"小白学视觉"微信公众号,欢迎关注公众号 本文作者为小白,版权归人民邮电出版社发行所有,禁止转载,侵权必究! 经过几个月的努力,小白终于完成了市面上第一本OpenCV 4 ...

  6. opencv学习笔记17:梯度运算之laplacian算子及其应用

    laplacian算子理论 前文介绍了sobel算子及其函数使用 和scharr算子及其函数使用 使用方法 不同算子比较 sobel,和scharr算子:右边121列-左边121列.右边-3,10,3 ...

  7. opencv:边缘检测之Laplacian算子思想及实现

    Laplacian算子边缘检测的来源 在边缘部分求取一阶导数,你会看到极值的出现: 如果在边缘部分求二阶导数会出现什么情况? 从上例中我们可以推论检测边缘可以通过定位梯度值大于邻域的相素的方法找到(或 ...

  8. 【OpenCV 例程200篇】63. 图像锐化——Laplacian 算子

    [OpenCV 例程200篇]63. 图像锐化--Laplacian 算子 欢迎关注 『OpenCV 例程200篇』 系列,持续更新中 欢迎关注 『Python小白的OpenCV学习课』 系列,持续更 ...

  9. 一文解决Opencv四大经典算子——sobel算子、scharr算子、laplacian算子、canny算子

    Opencv四大算子 Sobel算子 Scharr算子 laplacian算子 canny算子 总结 边缘是像素值发生跃迁的位置,是图像的显著特征之一,在图像特征提取,对象检测,模式识别等方面都有重要 ...

最新文章

  1. webpack 安装卸载
  2. [c#]解决方案:需要“jquery”ScriptResourceMapping。请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping。
  3. npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! test_vue_0613@1.0.0 dev: 错误的解决方法
  4. linux curl https报错: curl: (35) SSL connect error
  5. python qtdesigner 提升类_python3+PyQt5+Qt Designer实现扩展对话框
  6. Jersey Restful部署到Tomcat注意事项
  7. android 嵌套分组拖动_GitHub - Mosect/DragLayout: Android拖拽控件,支持上下左右滑动、折叠或者嵌套ListView、RecyclerView等...
  8. 【渝粤题库】陕西师范大学151210 成本会计作业 (专升本)
  9. 1065. 单身狗(25)
  10. Diango博客--2.博客从“裸奔”到“有皮肤”
  11. Linux多线程实践(2) --线程基本API
  12. 数据3分钟丨Oracle Database 21c终于发布而22c可能直接跳过;2021 OceanBase数据库大赛开启。...
  13. Mybatis学习笔记-CURD(基于配置文件的方式)
  14. 互联网金融数据分析-笔记
  15. Quoc Le,谷歌AutoML的幕后英雄
  16. 怎样手工清除autorun病毒
  17. linux下ruby安装步骤,Ruby 安装 - Linux
  18. 王者荣耀服务器不稳定总是跳频,vivo iQOO Pro 5G手机打玩王者荣耀网络不稳定出现断流...
  19. 日常英语精彩短句集锦
  20. 【C语言】机试100题及代码答案(上)

热门文章

  1. AppLaunchScreen/Screenshot(启动图/屏幕快照)输出规范
  2. UVA - 10859 Placing Lampposts 放置街灯
  3. canvas requestAnimationFrame 动画
  4. 安庆移动开展VoLTE网络测试
  5. nginx安装及编译参数详解
  6. Linux系统的文件句柄数量问题
  7. 链表的各种操作实现 链表逆序 链表排序 有序链表归并 链表存在环的判定
  8. 【数据挖掘知识点七】相关与回归分析
  9. vc6.0制作窗体可嵌入IE内的OCX
  10. ms speech sdk51 TTS使用