OpenCV图像滤波(18)空间梯度计算函数spatialGradient()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

计算图像在x和y两个方向上的一阶导数,使用Sobel算子。
等价于调用:

Sobel( src, dx, CV_16SC1, 1, 0, 3 );
Sobel( src, dy, CV_16SC1, 0, 1, 3 );

spatialGradient() 函数主要用于图像处理和计算机视觉领域,通常是在像 OpenCV 或 MATLAB 这样的计算框架中使用。该函数的主要目的是计算图像的空间梯度,这对于边缘检测和特征提取非常重要。

函数原型

void cv::spatialGradient	
(
	InputArray 	src,
	OutputArray 	dx,
	OutputArray 	dy,
	int 	ksize = 3,
	int 	borderType = BORDER_DEFAULT 
)		

参数

  • 参数src 原始输入图像。
  • 参数dx 输出图像,包含x方向上的一阶导数。
  • 参数dy 输出图像,包含y方向上的一阶导数。
  • 参数ksize Sobel算子的大小,必须设置为3。
  • 参数orderType 边界处理方式,默认为BORDER_DEFAULT,这通常是BORDER_REFLECT_101。BORDER_REPLICATE也是一种支持的边界处理方式。

代码示例


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

int main()
{
    // 加载原始图像
    cv::Mat src = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/erik.jpg", cv::IMREAD_GRAYSCALE );

    if ( src.empty() )
    {
        std::cout << "Could not open or find the image" << std::endl;
        return -1;
    }

    cv::Size sz2Sh( 400, 600 );
    cv::resize( src, src, sz2Sh, 0, 0, cv::INTER_LINEAR_EXACT );

    // 定义输出图像
    cv::Mat dx, dy;

    cv::spatialGradient(src, dx, dy);

    // 转换回 CV_8U
    cv::convertScaleAbs( dx, dx );
    cv::convertScaleAbs( dy, dy );

    // 显示梯度图像
    imshow("origianl image", src);
    cv::imshow( "Gradient X", dx );
    cv::imshow( "Gradient Y", dy );

    cv::waitKey();

    return 0;
}

运行结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值