OpenCV图像滤波(7)cv::getDerivKernels() 函数的使用

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

算法描述

函数返回用于计算空间图像导数的滤波系数。
该函数计算并返回用于空间图像导数的滤波系数。当 ksize=FILTER_SCHARR 时,生成 Scharr 3x3 核(参见 Scharr)。否则,生成 Sobel 核(参见 Sobel)。这些滤波器通常传递给 sepFilter2D 或其他函数。

这些系数可以用于计算图像的梯度,这对于边缘检测和其他基于梯度的图像处理任务非常重要。

函数原型

void cv::getDerivKernels	
(
	OutputArray 	kx,
	OutputArray 	ky,
	int 	dx,
	int 	dy,
	int 	ksize,
	bool 	normalize = false,
	int 	ktype = CV_32F 
)		

参数

  • 参数kx 输出矩阵,包含行滤波系数。其类型为 ktype。
  • 参数ky 输出矩阵,包含列滤波系数。其类型为 ktype。
  • 参数dx 关于 x 的导数阶数。
  • 参数dy 关于 y 的导数阶数。
  • 参数ksize 孔径大小。它可以是 FILTER_SCHARR、1、3、5 或 7
  • 参数normalize 标志,指示是否归一化(缩放)滤波系数。理论上,系数应该具有分母 =2 * ksize^2 - dx - dy - 2。如果你打算过滤浮点图像,你可能会使用归一化的内核。但是,如果你计算 8 位图像的导数,将结果存储在 16 位图像中,并希望保留所有的小数位,你可能想要设置 normalize=false。
  • 参数ktype 这是指滤波系数的数据类型。它可以是 CV_32F(32 位浮点数)或 CV_64F(64 位浮点数)。

示例代码

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

int main( int argc, char** argv )
{
    // 读取图像
    cv::Mat src = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/erik.jpg", cv::IMREAD_GRAYSCALE );

    if ( src.empty() )
    {
        std::cout << "Error: Image cannot be loaded!" << std::endl;
        return -1;
    }
    cv::Size sz2Sh( 400, 600 );

    cv::resize( src, src, sz2Sh, 0, 0, cv::INTER_LINEAR_EXACT );

    imshow( "原图", src );

    cv::Mat dst;

    cv::Mat kx, ky;
    cv::getDerivKernels( kx, ky, 1, 0, 3, false );
    cv::sepFilter2D( src, dst, src.depth(), kx, ky );
    imshow( "sepFilter2D", dst );

    cv::waitKey( 0 );
    return 0;
}

运行结果

参数是cv::getDerivKernels( kx, ky, 1, 0, 3, false )时:
在这里插入图片描述

参数是cv::getDerivKernels( kx, ky, 1, 0, 5, false )时:
在这里插入图片描述

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中使用OpenCV进行图像滤波可以通过调用OpenCV提供的函数来实现。图像滤波是一种常用的图像处理技术,可以用于去除图像中的噪声、平滑图像、边缘检测等。 OpenCV提供了多种图像滤波函数,常用的包括均值滤波、中值滤波、高斯滤波等。下面我将介绍其中几种常用的图像滤波方法: 1. 均值滤波(平滑滤波): 均值滤波是一种简单的滤波方法,它将图像中每个像素的值替换为其周围像素的平均值。在OpenCV中,可以使用`blur`函数来实现均值滤波。 ```cpp #include <opencv2/opencv.hpp> int main() { cv::Mat srcImage = cv::imread("input.jpg"); cv::Mat dstImage; cv::blur(srcImage, dstImage, cv::Size(3, 3)); cv::imshow("Input Image", srcImage); cv::imshow("Output Image", dstImage); cv::waitKey(0); return 0; } ``` 2. 中值滤波: 中值滤波是一种非线性滤波方法,它将图像中每个像素的值替换为其周围像素的中值。中值滤波对于去除椒盐噪声等有很好的效果。在OpenCV中,可以使用`medianBlur`函数来实现中值滤波。 ```cpp #include <opencv2/opencv.hpp> int main() { cv::Mat srcImage = cv::imread("input.jpg"); cv::Mat dstImage; cv::medianBlur(srcImage, dstImage, 3); cv::imshow("Input Image", srcImage); cv::imshow("Output Image", dstImage); cv::waitKey(0); return 0; } ``` 3. 高斯滤波: 高斯滤波是一种线性滤波方法,它将图像中每个像素的值替换为其周围像素的加权平均值,权重由高斯函数计算得到。高斯滤波可以有效地平滑图像并保留图像的边缘信息。在OpenCV中,可以使用`GaussianBlur`函数来实现高斯滤波。 ```cpp #include <opencv2/opencv.hpp> int main() { cv::Mat srcImage = cv::imread("input.jpg"); cv::Mat dstImage; cv::GaussianBlur(srcImage, dstImage, cv::Size(3, 3), 0); cv::imshow("Input Image", srcImage); cv::imshow("Output Image", dstImage); cv::waitKey(0); return 0; } ``` 以上是几种常用的图像滤波方法的示例代码,你可以根据自己的需求选择合适的滤波方法进行图像处理。如果你有其他关于图像滤波的问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值