char mat转为unsigned_OpenCV mat数据类型及位数(转)

本文介绍了OpenCV中不同数据类型及其内存占用,强调了正确选择数据类型以匹配图像文件格式的重要性。例如,8位无符号整型(uchar/CV_8UC1等)常用于表示0-255范围的图像数据,避免内存浪费。同时,讨论了正负号的处理,如浮点型和整型在表示图像数据时的区别。
摘要由CSDN通过智能技术生成

float:  4字节

6-7位有效数字 -3.4E-38 到

3.4E38 double: 8字节 15~16位有效数字 -1.7E-308 到 1.7E308

在OpenCV里面,许多数据结构为了达到內存使用的最优化,通常都会给它最小上限的空间来分配变量,有的数据结构也会因为图像文件格式的关系而给予适当的变量,因此需要知道它们声明的空间大小来配置适当的变量.

般标准的图片,为RGB格式它们的大小为8bits格式,范围为0~255,对一个int空间的类型来说实在是太小,整整浪费了24bits的空间,假设有个640*480的BMP文件空间存储內存,那整整浪费了640*480*3*(32-8)bits的內存空间,总共浪费了2.6MB!,也就是那

2.6MB内什么东西都没存储,如果今天以8bits的格式来存储则只使用到0.6MB的內存而已(640*480*3*(8)+54

bits),因此,对于文件格式的对应是一件很重要的事。

在这边除了要考虑bits的空间外,还要考虑使用类型的正负号的问题,一般的图像

文件是不存在负号的,如果今天即使选对空间,可是出现的结果却是负的,那就功亏一篑了.这里除了Float及double类

型,char,int,short int都是用二的补数表示法,它们不具正负号bit,而Float,double则是用IEEE

754,在第32bit,64bit上有一个正负号bit.

cvCreateImage()及cvCreateMat()对应

1.Unsigned 8bits(一般的图像文件格式使用的大小)

IplImage数据结构参数:IPL_DEPTH_8U

CvMat数据结构参数:CV_8UC1,CV_8UC2,CV_8UC3,CV_8UC4

变量类型空间大小范围其他uchar8bits0~255(OpenCV缺省变量,同等unsigned

char)unsign

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值