OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()

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

算法描述

在 GPU 上对图像执行 均值漂移滤波(Mean Shift Filtering),用于图像分割或平滑处理。

该函数将输入图像中的每个像素用其邻域内颜色分布的"模式"代替,从而实现:

  • 颜色平滑(去除噪声)
  • 边界保持
  • 图像分割的预处理

函数原型

cpp 复制代码
void cv::cuda::meanShiftFiltering 	
(
 	InputArray  	src,
	OutputArray  	dst,
	int  	sp,
	int  	sr,
	TermCriteria  	criteria = TermCriteria(TermCriteria::MAX_ITER+TermCriteria::EPS, 5, 1),
	Stream &  	stream = Stream::Null() 
) 	

参数

  • src 源图像。目前仅支持 CV_8UC4 类型的图像(即:8位无符号整型、4通道图像)。
  • dst 目标图像,包含映射后的点的颜色。它与源图像具有相同的尺寸和类型。
  • sp 空间窗口半径(以像素为单位)。
  • sr 颜色窗口半径(以颜色差异为单位)。
  • criteria 终止条件。参见 TermCriteria 结构体,用于控制算法迭代的最大次数或收敛精度。
  • stream 用于异步执行的 CUDA 流(Stream)。

代码示例

cpp 复制代码
#include <opencv2/cudaimgproc.hpp>
#include <opencv2/opencv.hpp>

int main()
{
    // Step 1: 读取图像
    cv::Mat h_src = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/Lenna.png" );
    if ( h_src.empty() )
    {
        std::cerr << "Failed to load image!" << std::endl;
        return -1;
    }

    // Step 2: 转换为 4 通道图像(BGRA)
    cv::cuda::GpuMat d_src, d_src_rgba;
    d_src.upload( h_src );
    cv::cuda::cvtColor( d_src, d_src_rgba, cv::COLOR_BGR2BGRA );  // 转为 CV_8UC4

    // Step 3: 创建输出图像
    cv::cuda::GpuMat d_dst;

    // Step 4: 设置参数并执行均值漂移滤波
    int sp = 10;  // 空间窗口大小
    int sr = 30;  // 颜色窗口大小
    cv::cuda::meanShiftFiltering( d_src_rgba, d_dst, sp, sr );

    // Step 5: 下载结果并显示
    cv::Mat h_dst;
    d_dst.download( h_dst );

    // Step 6: 如果需要恢复为 3 通道图像
    cv::cuda::GpuMat d_dst_bgr;
    cv::cuda::cvtColor( d_dst, d_dst_bgr, cv::COLOR_BGRA2BGR );

    cv::Mat h_final;
    d_dst_bgr.download( h_final );

    cv::imshow( "Original Image", h_src );
    cv::imshow( "Filtered Image", h_final );
    cv::waitKey( 0 );

    return 0;
}

运行结果

相关推荐
jndingxin5 小时前
OPenCV CUDA模块目标检测----- HOG 特征提取和目标检测类cv::cuda::HOG
人工智能·opencv·目标检测
清醒的兰5 小时前
OpenCV 图像像素的逻辑操作
人工智能·opencv·计算机视觉
ACQTEC研索仪器8 小时前
案例分享--汽车制动卡钳DIC测量
图像处理·汽车·dic·数字图像相关·vic-3d非接触全场应变测量
新知图书11 小时前
OpenCV在图像上绘制文字示例
人工智能·opencv·计算机视觉
KerwinChou_CN12 小时前
自由开发者计划 004:创建一个苹果手机长截屏小程序
图像处理·算法·智能手机·小程序
天天代码码天天1 天前
C# Onnx 动漫人物头部检测
人工智能·深度学习·神经网络·opencv·目标检测·机器学习·计算机视觉
s153351 天前
8.RV1126-OPENCV 视频中添加LOGO
人工智能·opencv·音视频
whoarethenext1 天前
OpenCV C/C++ 视频播放器 (支持调速和进度控制)
c语言·c++·opencv
阿松のblog1 天前
opencv使用经典bug
人工智能·opencv·bug
SuperW1 天前
OPENCV重点结构体Mat的讲解
人工智能·opencv·计算机视觉