OpenCV运动分析和目标跟踪(2)累积操作函数accumulateSquare()的使用

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

算法描述

将源图像的平方加到累积器图像中。

该函数将输入图像 src 或其选定区域提升到2的幂次方,然后加到累积器 dst 中:
dst ( x , y ) ← dst ( x , y ) + src ( x , y ) 2 if mask ( x , y ) ≠ 0 \texttt{dst} (x,y) \leftarrow \texttt{dst} (x,y) + \texttt{src} (x,y)^2 \quad \text{if} \quad \texttt{mask} (x,y) \ne 0 dst(x,y)←dst(x,y)+src(x,y)2ifmask(x,y)=0

函数支持多通道图像。每个通道独立处理。

函数原型

cpp 复制代码
void cv::accumulateSquare	
(
	InputArray 	src,
	InputOutputArray 	dst,
	InputArray 	mask = noArray() 
)	

参数

  • 参数src 输入图像,可以是单通道或三通道,8位或32位浮点数。
  • 参数dst 累积器图像,通道数与输入图像相同,32位或64位浮点数。
  • 参数mask 可选的操作掩码。

代码示例

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

int main()
{
    // 加载图像
    cv::Mat frame = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/hawk.jpg", cv::IMREAD_GRAYSCALE );
    if ( !frame.data )
    {
        std::cout << "Could not open or find the image" << std::endl;
        return -1;
    }

    // 初始化累积平方和
    cv::Mat sqSum = cv::Mat::zeros( frame.size(), CV_32F );

    // 模拟多帧累积
    for ( int i = 0; i < 100; ++i )
    {
        // 使用同一图像多次以模拟多帧情况
        cv::accumulateSquare( frame, sqSum );
    }

    // 防止累积平方和为0的情况
    sqSum += 1;  // 添加一个小常数避免分母为0

    // 计算累积平方和的最大值
    double maxVal;
    cv::minMaxLoc( sqSum, nullptr, &maxVal );

    // 将累积平方和转换回8位图像以便保存
    sqSum.convertTo( sqSum, CV_8U, 255.0 / maxVal );  // 归一化

    // 显示原始图像
    cv::imshow( "Original Image", frame );

    // 显示累积平方和结果图像
    cv::imshow( "Accumulated Square Result", sqSum );

    // 等待按键,以便查看图像
    cv::waitKey( 0 );

    // 关闭所有窗口
    cv::destroyAllWindows();

    // 保存结果
    cv::imwrite( "accumulated_square_result.jpg", sqSum );

    return 0;
}

运行结果

相关推荐
Raink老师4 小时前
【AI面试临阵磨枪】详细解释 Transformer 架构的核心组件与工作流程。
人工智能·深度学习·transformer·ai 面试·ai 应用开发
qcx234 小时前
【AI Agent实战】OpenClaw 安全加固完全指南:安全攻击手段与五步防护实践(2026最新)
人工智能·安全
码农小白AI5 小时前
AI报告审核进入技术驱动时代:IACheck如何从规则引擎走向深度学习,构建检测报告审核“技术矩阵”
人工智能·深度学习
song150265372985 小时前
视觉检测设备:自动识别缺陷、尺寸、瑕疵、装配错误,一键全检
人工智能·计算机视觉·视觉检测
智能化咨询5 小时前
(163页PPT)某著名企业K3生产制造售前营销指导方案P164(附下载方式)
大数据·人工智能
Zzj_tju5 小时前
大语言模型技术指南:SFT、RLHF、DPO 怎么串起来?对齐训练与关键参数详解
人工智能·深度学习·语言模型
金智维科技官方5 小时前
RPA技术赋能电信运营商话单稽核:金智维如何驱动高精度自动化转型
人工智能·自动化·数字化·rpa·智能体·电信
2501_948114245 小时前
2026模型能力分化加剧:多模型聚合架构的技术解析与工程落地思考
人工智能·ai·chatgpt·架构
新知图书6 小时前
LangGraph中的记忆存储
人工智能·langgraph·智能体设计·多智能体设计
冬奇Lab6 小时前
Claude Code 实战经验分享(上篇):从启动到并发协同
人工智能·ai编程·claude