• 【OpenCV4】拉普拉斯算子提取边缘 cv::Laplacian() 用法详解和代码示例(c++)


    作用原理:

    拉普拉斯算子可以用于边缘检测,同时该算子不具有方向性,可以同时检测到 X 方向和 Y 方向的边缘,综合后检测出图像的边缘。

    即拉普拉斯算子是 各向同性 的,这在很多情况下是一个优点,因为我们一般来说会同时关注 X 方向和 Y 方向的边缘,所以这时候就不需要做两次,一次边缘检测就能得到结果。

    这里要注意的是,拉普拉斯算子是一种 二阶导数 算子,所以对噪声很敏感,在实际运用中通常会搭配高斯滤波一起用。

    公式:

    在这里插入图片描述

    函数原型:

    
    void cv::Laplacian	(	InputArray 	src,
    						OutputArray 	dst,
    						int 	ddepth,
    						int 	ksize = 1,
    						double 	scale = 1,
    						double 	delta = 0,
    						int 	borderType = BORDER_DEFAULT 
    						)	
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    解析:

    • src:输入图像
    • dst:输出图像(尺寸和通道数与输入一致)
    • ddepth:目标数据类型(位深,比如 CV_32F)
    • ksize:用于计算滤波器二阶导数的孔径尺寸(必须是正奇数)
    • scale:计算所得拉普拉斯值的缩放因子(可选,默认没有缩放)
    • delta:对计算结果整体做一个正向偏移(可选,默认没有偏移)
    • borderType:边界外推方法

    注: 当 ksize=1 时,拉普拉斯算子滤波器为 3X3 的孔径,如下:
    在这里插入图片描述
    后三个参数一般选择默认值

    代码示例:

    void TestLaplacian()
    {
        cv::Mat lena = cv::imread("lena.jpg", 1);
        cv::Mat blured;
        cv::Mat result_1;
        cv::Mat result_2;
    
        cv::GaussianBlur(lena, blured, cv::Size(5, 5), 0, 0);
        cv::Laplacian(lena, result_1, CV_32F);
        cv::Laplacian(blured, result_2, CV_32F);
    
        cv::imshow("lena", lena);
        cv::imshow("result_1", result_1);
        cv::imshow("result_2", result_2);
        cv::waitKey(0);
    
        return;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    原图:
    在这里插入图片描述
    单独使用拉普拉斯算子进行边缘检测:
    在这里插入图片描述
    先用高斯滤波,再用拉普拉斯算子进行边缘检测:
    在这里插入图片描述
    可以看到,搭配使用后效果更佳

  • 相关阅读:
    【数据结构】栈和队列的模拟实现
    vue2+element医院安全(不良)事件报告管理系统源代码
    【oncmdmsg 鼠标】2023/8/19 上午9:50:14
    ORACLE多列中取出数据最大的一条
    基于物联网的水质监测系统设计与实现:React前端、Node.js后端与TCP/IP协议的云平台集成(代码示例)
    强网杯2022——WEB
    猿创征文|运维工具介绍
    好用且免费的ChatGPT工具
    单片机和ARM A的区别
    哺乳期哪些事不能做?
  • 原文地址:https://blog.csdn.net/qq_42067550/article/details/126347478