OpenCV 图形API(69)图像与通道拼接函数------将一个 GMat 类型的对象转换为另一个具有不同深度GMat对象函数convertTo()

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

算法描述

将一个矩阵转换为另一种数据深度,并可选择进行缩放。

该方法将源像素值转换为目标数据深度。最终应用 saturate_cast<> 以避免可能出现的数据溢出情况:
m ( x , y ) = s a t u r a t e _ c a s t < r T y p e > ( α ( ∗ t h i s ) ( x , y ) + β ) m(x,y) = saturate \_ cast<rType>( \alpha (*this)(x,y) + \beta ) m(x,y)=saturate_cast<rType>(α(∗this)(x,y)+β)

输出矩阵必须与输入矩阵大小相同。

注意

此函数的文本标识符是 "org.opencv.core.transform.convertTo"。

函数原型

cpp 复制代码
GMat cv::gapi::convertTo 	
(
 	const GMat &  	src,
	int  	rdepth,
	double  	alpha = 1,
	double  	beta = 0 
) 	

参数

  • 参数 src: 需要被转换的输入矩阵。
  • 参数 rdepth: 目标输出矩阵的数据深度,更确切地说是深度(因为通道数量与输入相同);如果 rdepth 是负数,则输出矩阵将具有与输入相同的深度。
  • 参数 alpha: 可选的比例因子。
  • 参数 beta: 添加到缩放值的可选增量。

代码示例

cpp 复制代码
#include <iomanip>  // For std::setprecision
#include <iostream>
#include <opencv2/gapi.hpp>
#include <opencv2/gapi/core.hpp>
#include <opencv2/opencv.hpp>

int main()
{
    // 创建一个 G-API 图像处理图
    cv::GMat in;

    // 定义转换操作:例如从 CV_8U 转换到 CV_32F,并应用 alpha 和 beta
    int rdepth   = CV_32F;  // 目标深度,这里是32位浮点数
    double alpha = 1.0;     // 缩放因子
    double beta  = 0.0;     // 增量值

    // 使用 convertTo 方法
    cv::GMat dst = cv::gapi::convertTo( in, rdepth, alpha, beta );

    // 定义 G-API 图(graph)和编译它
    cv::GComputation graph( cv::GIn( in ), cv::GOut( dst ) );

    // 准备输入数据:这里以随机生成的数据为例
    cv::Mat src_mat = ( cv::Mat_< uchar >( 3, 3 ) << 1, 2, 3, 4, 5, 6, 7, 8, 9 );  // 示例8位无符号整数矩阵

    cv::Mat dst_mat;

    // 在输入数据上运行 G-API 图像处理图
    graph.apply( src_mat, dst_mat, cv::compile_args( cv::gapi::kernels() ) );

    // 输出结果
    std::cout << "Original matrix (type CV_8U):\n" << src_mat << std::endl;
    std::cout << "Converted matrix (type CV_32F):\n";
    std::cout << std::fixed << std::setprecision( 1 );  // 设置浮点数输出格式
    for ( int i = 0; i < dst_mat.rows; ++i )
    {
        for ( int j = 0; j < dst_mat.cols; ++j )
        {
            std::cout << dst_mat.at< float >( i, j ) << " ";
        }
        std::cout << "\n";
    }

    return 0;
}

运行结果

bash 复制代码
Original matrix (type CV_8U):
[  1,   2,   3;
   4,   5,   6;
   7,   8,   9]
Converted matrix (type CV_32F):
1.0 2.0 3.0 
4.0 5.0 6.0 
7.0 8.0 9.0 
相关推荐
聆风吟º5 小时前
CANN runtime 实战指南:异构计算场景中运行时组件的部署、调优与扩展技巧
人工智能·神经网络·cann·异构计算
Codebee7 小时前
能力中心 (Agent SkillCenter):开启AI技能管理新时代
人工智能
聆风吟º8 小时前
CANN runtime 全链路拆解:AI 异构计算运行时的任务管理与功能适配技术路径
人工智能·深度学习·神经网络·cann
uesowys8 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
AI_56788 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
User_芊芊君子8 小时前
CANN大模型推理加速引擎ascend-transformer-boost深度解析:毫秒级响应的Transformer优化方案
人工智能·深度学习·transformer
智驱力人工智能9 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
qq_160144879 小时前
亲测!2026年零基础学AI的入门干货,新手照做就能上手
人工智能
Howie Zphile9 小时前
全面预算管理难以落地的核心真相:“完美模型幻觉”的认知误区
人工智能·全面预算
人工不智能5779 小时前
拆解 BERT:Output 中的 Hidden States 到底藏了什么秘密?
人工智能·深度学习·bert