Mat::type函数返回值的意义及数据的转换Mat::convertTo

2024-02-22 20:18

本文主要是介绍Mat::type函数返回值的意义及数据的转换Mat::convertTo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(1)Mat类型容器的数据类型

调用Mat::type函数可以查看Mat容器对象数据的属性,其返回值对应不同数据类型和通道数,如下表所示。

 

 举例说明:

  1. Mat image(300, 300, CV_8UC1);  
  2. cout << image.type() << endl;  

上面两行函数建立了一个CV_8UC1的Mat类对象image,则调用其type函数得到的返回值为0。

对应上表可以看到:数据格式为CV_8U,单通道(C1 means One Channel)。

同理,假设读入一幅图像,也可以查看他的数据属性,如下例:

  1. Mat image;  
  2. image = imread("1.png");  
  3. cout << image.type() << endl;  

假设返回值为16,通过上表,则可以知道被读入的图像是CV_8UC3的属性。

 

(2)对数据类型的修改

利用Mat::convertTo(OutputArray m, int rtype, double alpha=1, double beta=0)函数实现不同数据类型之间的转换。其中:

m:【输出量】就是盛放转换后数据的容器;

rtype:【输入量】目标数据类型;

alpha:【输入量】放缩尺度;

beta:【输入量】偏置量;

如下代码:

cv::Mat Src(100, 100, CV_8UC1, cv::Scalar(125));
cv::Mat Dst;
double alpha = 0.8, beta = 1.5;
Src.convertTo(Dst, CV_32FC1, alpha, beta);

表示我们新建了一个100*100的单通道矩阵Src,数据类型是uchar,所有位置填充125;

我们将Src转换为数据类型为float的矩阵,同时对矩阵内每一个元素执行如下操作:

Dst(x,y) = \alpha \times Src(x,y) + \beta

最终转换完成后的数据,放在Dst矩阵中。

这篇关于Mat::type函数返回值的意义及数据的转换Mat::convertTo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/736391

相关文章

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据