OpenCV 图形API(10)用于执行标量除以矩阵的逐元素操作函数divRC()

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

描述

标量除以矩阵。

函数 divRC 将给定的标量除以矩阵 src 的每个元素,并将结果保存在与 src 具有相同大小和类型的新的矩阵中:
dst(I) = saturate(divident*scale/src(I)) \texttt{dst(I) = saturate(divident*scale/src(I))} dst(I) = saturate(divident*scale/src(I))

当 src(I) 为零时,dst(I) 也将为零。多通道矩阵的不同通道独立处理。矩阵可以是单通道或多通道。输出矩阵必须与 src 具有相同的大小和深度。

支持的矩阵数据类型为 CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1。

cv::gapi::divRC 函数用于执行标量除以矩阵的逐元素操作,并可以选择性地应用缩放因子和指定输出数据类型深度。与 cv::gapi::divC 不同,divRC 是将一个标量(被除数)除以矩阵中的每个元素(除数),而不是相反。

函数原型

cpp 复制代码
GMat cv::gapi::divRC 	
(
 	const GScalar &  	divident,
	const GMat &  	src,
	double  	scale,
	int  	ddepth = -1 
) 		

参数

  • 参数src:输入矩阵。
  • 参数divident:要被除的数(被除数)。
  • 参数ddepth:输出矩阵的可选深度。如果为 -1,则输出矩阵的深度将与输入矩阵的深度相同。
  • 参数scale:缩放因子。

返回值

返回一个 GMat 对象,表示标量除以矩阵中每个元素并经过缩放后的结果。

代码示例

cpp 复制代码
#include <iostream>
#include <opencv2/gapi/core.hpp>  // 包含G-API核心功能
#include <opencv2/opencv.hpp>

int main()
{
    // 创建示例数据
    cv::Mat src = ( cv::Mat_< float >( 2, 2 ) << 2.0f, 4.0f, 8.0f, 16.0f );
    cv::Scalar divident( 16.0 );  // 标量被除数
    double scale = 1.0;           // 缩放因子

    // 检查输入矩阵是否为空
    if ( src.empty() )
    {
        std::cerr << "无法加载输入矩阵,请检查数据。" << std::endl;
        return -1;
    }

    // 定义G-API图中的输入
    cv::GScalar gdivident( divident );
    cv::GMat gsrc;
    int ddepth = -1;  // 使用默认深度

    // 执行除法操作
    auto gdst = cv::gapi::divRC( gdivident, gsrc, scale, ddepth );

    // 创建一个计算图
    cv::GComputation div_graph( cv::GIn( gsrc ), cv::GOut( gdst ) );

    // 输出矩阵
    cv::Mat result;

    // 编译并执行计算图
    div_graph.apply( cv::gin( src ), cv::gout( result ) );

    // 打印结果
    std::cout << "Result: \n" << result << std::endl;

    return 0;
}

运行结果

bash 复制代码
Result: 
[8, 4;
 2, 1]
相关推荐
陈天伟教授几秒前
小白快速进阶- AI辅助编码
人工智能·神经网络·机器学习·量子计算
AI成长日志7 分钟前
【GitHub开源项目专栏】黑客松获奖项目技术深潜:从垂直领域AI到安全基础设施的创新实践
人工智能·开源·github
H Journey18 分钟前
openCV图像学-二值化
人工智能·opencv·计算机视觉
算法即正义18 分钟前
知识竞赛计分规则设置指南:七种计分模式详解与实操建议
人工智能
这张生成的图像能检测吗21 分钟前
(论文速读)基于微调大语言模型的数控车床故障诊断
人工智能·语言模型·故障诊断·车床技术
大写-凌祁22 分钟前
RescueADI:基于自主智能体的遥感图像自适应灾害解译
人工智能·计算机视觉·语言模型·自然语言处理·aigc
fof92026 分钟前
Base LLM | 从 NLP 到 LLM 的算法全栈教程 第六天
人工智能·自然语言处理
Godspeed Zhao29 分钟前
科技信息最前沿——TurboQuant:以极致压缩重新定义人工智能效率
人工智能·科技
AI医影跨模态组学31 分钟前
Radiology子刊(IF=6.3)复旦大学附属金山医院强金伟教授等团队:基于多参数MRI的深度学习和影像组学评估早期宫颈癌淋巴结转移
人工智能·深度学习·论文·医学·医学影像
Ln5x9qZC232 分钟前
Laravel AI SDK 正式发布
android·人工智能·laravel