当前位置: 首页 > article >正文

OpenCV CUDA模块结构分析与形状描述符------在 GPU 上计算图像的原始矩(spatial moments)函数spatialMoments()

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

算法描述

该函数用于在 GPU 上计算图像的原始矩(spatial moments)。这些矩可用于描述图像中物体的形状特征,如面积、质心等。

与 cv::cuda::moments(…) 不同的是,这个函数将结果写入一个 OutputArray 中,而不是返回结构体。因此它更适合需要手动处理矩数组的应用场景。

参数

参数名类型描述
srcInputArray输入图像,支持 CV_8U, CV_16U, 或 CV_32S 类型,单通道图像。如果 binaryImage 为 true,则应为二值图像(前景非零,背景为零)。
momentsOutputArray输出矩数组,是一个一维数组,长度由 order 决定(见下文),数据类型由 momentsType 指定。
binaryImageconst bool如果为 true,则假设输入图像是二值图像;否则按灰度图处理。默认为 false。
orderconst MomentsOrder要计算的矩的最大阶数,可选:
- FIRST_ORDER_MOMENTS:仅计算到一阶矩(共 4 个矩)
- SECOND_ORDER_MOMENTS:计算到二阶矩(共 9 个矩)
- THIRD_ORDER_MOMENTS:计算到三阶矩(共 16 个矩)
momentsTypeconst int矩的数据类型,通常为 CV_64F(双精度浮点数),也可以是 CV_32F。
streamStream&可选的 CUDA 流对象,用于异步执行。默认为同步执行(Stream::Null())。

注意:

为了获得最佳性能,请预先分配一个一维 GpuMat 用于存储矩(moments),其类型和大小必须足以容纳指定阶数下的所有图像矩。

例如:当 order == MomentsOrder::SECOND_ORDER_MOMENTS 且 momentsType == CV_32F 时,可以这样分配:

GpuMat momentsDevice(1, numMoments(MomentsOrder::SECOND_ORDER_MOMENTS), CV_32F);

下载矩数组后,可以在主机端使用 cv::Moments 构造函数轻松地计算中心矩(central moments)和归一化矩(normalized moments)。例如:

HostMem momentsHostMem(1, numMoments(MomentsOrder::SECOND_ORDER_MOMENTS), CV_32F);
momentsDevice.download(momentsHostMem, stream);
stream.waitForCompletion();
Mat momentsMat = momentsHostMem.createMatHeader();
cv::Moments cvMoments(momentsMat.at<float>(0), momentsMat.at<float>(1),momentsMat.at<float>(2), momentsMat.at<float>(3),momentsMat.at<float>(4), momentsMat.at<float>(5),momentsMat.at<float>(6), momentsMat.at<float>(7),momentsMat.at<float>(8), momentsMat.at<float>(9)
);

示例详见 OpenCV 贡献模块源码中的测试文件:
opencv_contrib_source_code/modules/cudaimgproc/test/test_moments.cpp 中的 CUDA_TEST_P(Moments, Async) 测试用例

返回值

无返回值。矩的结果通过 moments 参数输出。

代码示例

#include <opencv2/opencv.hpp>
#include <opencv2/cudaimgproc.hpp>
#include <iostream>int main()
{// 加载图像cv::Mat h_src = cv::imread("/media/dingxin/data/study/OpenCV/sources/images/Lenna.png", cv::IMREAD_GRAYSCALE);if (h_src.empty()){std::cerr << "无法加载图像!" << std::endl;return -1;}// 上传图像到 GPUcv::cuda::GpuMat d_src;d_src.upload(h_src);// 获取最大阶数下的矩数量int nMoments = cv::cuda::numMoments(cv::cuda::MomentsOrder::THIRD_ORDER_MOMENTS);// 创建输出矩阵cv::cuda::GpuMat d_moments;d_moments.create(1, nMoments, CV_64F);  // 存储所有矩值// 计算空间矩cv::cuda::spatialMoments(d_src, d_moments, false, cv::cuda::MomentsOrder::THIRD_ORDER_MOMENTS);// 下载结果cv::Mat h_moments;d_moments.download(h_moments);// 打印结果std::cout << "原始矩(spatial moments):" << std::endl;for (int i = 0; i < h_moments.cols; ++i){std::cout << "Moment[" << i << "] = " << h_moments.at<double>(i) << std::endl;}return 0;
}

运行结果

原始矩(spatial moments):
Moment[0] = 3.4715e+07
Moment[1] = 9.17605e+09
Moment[2] = 8.59234e+09
Moment[3] = 3.17604e+12
Moment[4] = 2.31525e+12
Moment[5] = 2.88234e+12
Moment[6] = 1.22333e+15
Moment[7] = 8.11918e+14
Moment[8] = 7.81631e+14
Moment[9] = 1.09583e+15
http://www.lryc.cn/news/2397425.html

相关文章:

  • QT入门学习(一)---新建工程与、信号与槽
  • UE5.4.4+Rider2024.3.7开发环境配置
  • Windows环境下PHP,在PowerShell控制台输出中文乱码
  • 第2篇:数据库连接池原理与自定义连接池开发实践
  • 性能优化 - 理论篇:性能优化的七类技术手段
  • 华为IP(7)
  • AIGC与影视制作:技术革命、产业重构与未来图景
  • spring-cloud-alibaba-sentinel-gateway
  • Cursor 玩转 腾讯地图 MCP Server
  • 【HarmonyOS 5】 ArkUI-X开发中的常见问题及解决方案
  • 2025年中国电商618年中大促策略分析:存量博弈与生态重构
  • Deepseek给出的8255显示例程
  • React+Antd全局加载遮罩工具
  • Qt OpenGL 光照实现
  • 智汇云舟携最新无人机2D地图快速重建技术亮相广西国际矿业展览会
  • Rust: CString、CStr和String、str
  • 力扣每日一题——连接两棵树后最大目标节点数目 ||
  • 【学习笔记】Sparse Crosscoders for Cross-Layer Features and Model Diffing
  • VSCode无法转到定义python源码(ctrl加单击不跳转)
  • 【华为战报】4月、5月 HCIP考试战报!
  • 开发指南120-表格(el-table)斑马纹
  • 数字化转型全场景安全解析:从产品到管理的防线构建与实施要点
  • AIGC工具平台-GPT-SoVITS-v4-TTS音频推理克隆
  • el-table配置表头固定而且高度变化
  • 设计模式——组合设计模式(结构型)
  • PostgreSQL 在生物信息学中的应用
  • EMO2:基于末端执行器引导的音频驱动虚拟形象视频生成
  • 计算机总线技术深度解析:从系统架构到前沿演进
  • Python打卡训练营Day43
  • PHP7+MySQL5.6 查立得轻量级公交查询系统