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

OpenCV CUDA模块中逐元素操作------算术运算

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

算法描述

算术运算:包括加法、减法、乘法和除法等基本运算。这些操作可以应用于两个相同尺寸的矩阵,或者一个矩阵与一个标量之间。例如,将两个图像矩阵相加可以用于图像合成。

主要函数

1. 加法操作 (cv::cuda::add)

功能: 对两个矩阵或一个矩阵和一个标量执行逐元素加法操作。

函数原型
void cv::cuda::add
(InputArray src1,        // 第一个输入矩阵或标量InputArray src2,        // 第二个输入矩阵或标量OutputArray dst,       // 输出矩阵const GpuMat& mask = GpuMat(), // 可选掩码矩阵int dtype = -1,        // 输出矩阵的数据类型(默认与输入相同)Stream& stream = Stream::Null() // 可选CUDA流
);
参数介绍
  • src1: 输入的第一个矩阵或标量。
  • src2: 输入的第二个矩阵或标量。
  • dst: 输出的结果矩阵。
  • mask: 可选的掩码矩阵,用于指定哪些像素参与计算,默认为空(不使用掩码)。
  • dtype: 输出矩阵的数据类型,如果设置为-1,则与输入矩阵相同。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

2. 减法操作 (cv::cuda::subtract)

功能: 对两个矩阵或一个矩阵和一个标量执行逐元素减法操作。

函数原型
void cv::cuda::subtract
(InputArray src1,InputArray src2,OutputArray dst,const GpuMat& mask = GpuMat(),int dtype = -1,Stream& stream = Stream::Null()
);
参数介绍
  • src1: 输入的第一个矩阵或标量。
  • src2: 输入的第二个矩阵或标量。
  • dst: 输出的结果矩阵。
  • mask: 可选的掩码矩阵,用于指定哪些像素参与计算,默认为空(不使用掩码)。
  • dtype: 输出矩阵的数据类型,如果设置为-1,则与输入矩阵相同。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

3. 乘法操作 (cv::cuda::multiply)

功能: 对两个矩阵或一个矩阵和一个标量执行逐元素乘法操作。

函数原型
void cv::cuda::multiply
(InputArray src1,InputArray src2,OutputArray dst,double scale = 1,      // 缩放因子,默认为1int dtype = -1,        // 输出矩阵的数据类型(默认与输入相同)Stream& stream = Stream::Null()
);

参数

  • src1: 输入的第一个矩阵或标量。
  • src2: 输入的第二个矩阵或标量。
  • dst: 输出的结果矩阵。
  • scale: 缩放因子,结果将乘以这个值,默认为1。
  • dtype: 输出矩阵的数据类型,如果设置为-1,则与输入矩阵相同。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

4. 除法操作 (cv::cuda::divide)

功能: 对两个矩阵或一个矩阵和一个标量执行逐元素除法操作。

函数原型
void cv::cuda::divide
(InputArray src1,InputArray src2,OutputArray dst,double scale = 1,      // 缩放因子,默认为1int dtype = -1,        // 输出矩阵的数据类型(默认与输入相同)Stream& stream = Stream::Null()
);
参数
  • src1: 输入的第一个矩阵或标量。
  • src2: 输入的第二个矩阵或标量。
  • dst: 输出的结果矩阵。
  • scale: 缩放因子,结果将乘以这个值,默认为1。
  • dtype: 输出矩阵的数据类型,如果设置为-1,则与输入矩阵相同。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

5. 绝对值 (cv::cuda::abs)

功能: 计算每个元素的绝对值,支持实数和复数类型。

函数原型
void cv::cuda::abs
(InputArray src,        // 输入矩阵OutputArray dst,       // 输出矩阵Stream& stream = Stream::Null()
);
参数
  • src: 输入的矩阵。
  • dst: 输出的结果矩阵。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

6. 绝对差值 (cv::cuda::absdiff)

功能: 计算两个数组对应元素差值的绝对值。

函数原型
void cv::cuda::absdiff
(InputArray src1,InputArray src2,OutputArray dst,Stream& stream = Stream::Null()
);
参数
  • src1: 输入的第一个矩阵。
  • src2: 输入的第二个矩阵。
  • dst: 输出的结果矩阵。
  • stream: CUDA流对象,用于控制操作的异步执行,默认为同步执行。

代码示例

#include <opencv2/cudaarithm.hpp>  // 包含CUDA算术运算头文件
#include <opencv2/opencv.hpp>int main()
{// 创建两个输入矩阵cv::Mat h_src1 = ( cv::Mat_< float >( 3, 3 ) << 1, 2, 3, 4, 5, 6, 7, 8, 9 );  // 第一个输入矩阵cv::Mat h_src2 = ( cv::Mat_< float >( 3, 3 ) << 9, 8, 7, 6, 5, 4, 3, 2, 1 );  // 第二个输入矩阵// 将它们上传到GPUcv::cuda::GpuMat d_src1, d_src2;d_src1.upload( h_src1 );d_src2.upload( h_src2 );// 定义输出矩阵cv::cuda::GpuMat d_dst;// 加法操作cv::cuda::add( d_src1, d_src2, d_dst );cv::Mat h_add;d_dst.download( h_add );std::cout << "Result (Addition):\n" << h_add << std::endl;// 减法操作cv::cuda::subtract( d_src1, d_src2, d_dst );cv::Mat h_subtract;d_dst.download( h_subtract );std::cout << "Result (Subtraction):\n" << h_subtract << std::endl;// 乘法操作cv::cuda::multiply( d_src1, d_src2, d_dst, 1.0, CV_32F );cv::Mat h_multiply;d_dst.download( h_multiply );std::cout << "Result (Multiplication):\n" << h_multiply << std::endl;// 除法操作cv::cuda::divide( d_src1, d_src2, d_dst, 1.0, CV_32F );cv::Mat h_divide;d_dst.download( h_divide );std::cout << "Result (Division):\n" << h_divide << std::endl;// 绝对差值cv::cuda::absdiff( d_src1, d_src2, d_dst );cv::Mat h_absdiff;d_dst.download( h_absdiff );std::cout << "Result (AbsDiff):\n" << h_absdiff << std::endl;return 0;
}

运行结果

Result (Addition):
[10, 10, 10;10, 10, 10;10, 10, 10]
Result (Subtraction):
[-8, -6, -4;-2, 0, 2;4, 6, 8]
Result (Multiplication):
[9, 16, 21;24, 25, 24;21, 16, 9]
Result (Division):
[0.11111111, 0.25, 0.42857143;0.66666669, 1, 1.5;2.3333333, 4, 9]
Result (AbsDiff):
[8, 6, 4;2, 0, 2;4, 6, 8]

相关文章:

  • 解密企业级大模型智能体Agentic AI 关键技术:MCP、A2A、Reasoning LLMs-强化学习算法
  • Vue3指令(二)--v-text、v-html数据渲染,计算属性
  • 50天50个小项目 (Vue3 + Tailwindcss V4) ✨ |搭建项目框架
  • PlantSimulation 隐藏 Frame节点(Structure)的操作方法
  • ComplianceAsCode/content 项目架构设计刨析
  • 西门子WinCC Unified PC的GraphQL使用手册
  • [python] python中的魔法方法和属性
  • Spring Boot 博客项目深度分析报告
  • k8s监控方案实践补充(一):部署Metrics Server实现kubectl top和HPA支持
  • iOS WebView和WKWebView怎么调试?
  • 行业趋势与技术创新:驾驭工业元宇宙与绿色智能制造
  • Large-Scale Language Models: In-Depth Principles and Pioneering Innovations
  • 【Linux网络】————详解TCP三次握手四次挥手
  • 【android bluetooth 协议分析 12】【A2DP详解 1】【车机侧蓝牙音乐免切源介绍】
  • AI时代的弯道超车之第八章:具体分享几个AI实际操作方法和案例
  • Kotlin Multiplatform与Flutter、Compose共存:构建高效跨平台应用的完整指南
  • [Spring]-组件的生命周期
  • 碎片笔记|AI生成图像溯源方法源码复现经验(持续更新中……)
  • 设计模式-中介者模式
  • 研读论文《Attention Is All You Need》(4)
  • 伊朗最高领袖顾问:伊朗愿承诺永不制造核武,换取美解除制裁
  • 为什么越来越多景区,把C位留给了书店?
  • 加强战略矿产出口全链条管控将重点开展哪些工作?商务部答问
  • 违法违规收集使用个人信息,爱奇艺、轻颜等65款App被点名
  • 大外交|巴西总统卢拉第六次访华签署20项协议,“双方都视对方为机遇”
  • 受贿3501万余元,中石油原董事长王宜林一审被判13年