OpenCV图像滤波(19)计算图像每个像素点的邻域内的平方和函数sqrBoxFilter()的使用

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

算法描述

计算覆盖在滤波器上的像素值的平方和。

对于源图像中的每一个像素 (x, y),函数计算那些与放置在像素 (x, y) 上的滤波器重叠的邻域像素值的平方和。

未归一化的平方盒滤波器可用于计算局部图像统计量,如像素邻域内的局部方差和标准差。

sqrBoxFilter() 函数通常用于图像处理中,用于计算图像中每个像素点的邻域内的平方和。这种操作对于计算局部方差或协方差等统计量非常有用。在 OpenCV 中,sqrBoxFilter() 函数可以用来高效地计算这种平方和。

函数原型

cpp 复制代码
void cv::sqrBoxFilter	
(
	InputArray 	src,
	OutputArray 	dst,
	int 	ddepth,
	Size 	ksize,
	Point 	anchor = Point(-1, -1),
	bool 	normalize = true,
	int 	borderType = BORDER_DEFAULT 
)		

参数

  • 参数src 输入图像。
  • 参数sdst 输出图像,与输入图像具有相同的尺寸和通道数。
  • 参数sddepth 输出图像的深度(-1 表示使用 src 的深度)。
  • 参数sksize 内核大小。
  • 参数anchor 内核的锚点位置,即内核的中心点。默认情况下,使用 Point(-1, -1) 表示锚点位于内核的中心。
  • 参数normalize 一个布尔标志,如果设置为 true,则结果会除以内核的面积进行归一化;如果为 false,则不进行归一化。
  • 参数borderType 边界处理方式,决定了如何处理图像边缘外的像素。BORDER_WRAP 不是一种支持的边界处理方式。

代码示例

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

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 dst;
    
    // 设置内核大小
    cv::Size ksize(1, 1); //1x1 内核
    
    // 使用 sqrBoxFilter 计算每个像素邻域内的平方和
    cv::sqrBoxFilter(src, dst, CV_64F, ksize, cv::Point(-1, -1), false, cv::BORDER_DEFAULT);
    
    // 显示结果图像
    cv::imshow("original image", src);
    cv::imshow("Square Sum", dst);
    
    cv::waitKey();
    
    return 0;
}

运行结果

相关推荐
唐天下文化几秒前
甜心速达智慧潮流精选超市、即时零售新业态,打造可持续发展商业模式
大数据·人工智能·零售
有杨既安然29 分钟前
Python自动化办公
开发语言·人工智能·深度学习·机器学习
何似在人间57538 分钟前
SpringAI+DeepSeek大模型应用开发——1 AI概述
java·人工智能·spring·springai
科技小E1 小时前
5G时代,视频分析设备平台EasyCVR实现通信基站远程安全便捷管控
大数据·网络·人工智能·音视频·安防监控
keepython1 小时前
【n8n docker 部署的代理问题】解决n8n部署无法访问openai等外国大模型厂商的api
运维·人工智能·docker·容器
訾博ZiBo1 小时前
AI日报 - 2025年4月18日
人工智能
胡萝卜不甜1 小时前
智能语音识别+1.2用SAPI实现文本转语音(100%教会)
人工智能·语音识别
小样vvv1 小时前
【AI】IDEA 集成 AI 工具的背景与意义
java·人工智能·intellij-idea
刘大猫262 小时前
Arthas watch (方法执行数据观测)
人工智能·数据分析·图像识别
jndingxin2 小时前
OpenCV 图形API(39)图像滤波----同时计算图像在 X 和 Y 方向上的一阶导数函数SobelXY()
人工智能·opencv·计算机视觉