matlab的double和single类型

原创 2013年09月04日 17:31:23

        看到博客(这里)中说,在matlab中, 当数据比较大时,运算起来就困难了,有时候还会out of memory。原因是默认情况下matlab用double存储数据。而double数据类型占8个字节,single类型占4个字节。把数据类型从double类型转换成single类型可以节省一半的空间。(如果怀疑可以用whos指令查看)。本来很有道理的,但是看到有人说(比如这里):The format function affects only how numbers are displayed, not how MATLAB computes or saves them. 不过从图上来看,似乎是能节省一半的存储空间的。

 

        至于从double到single能否提高运算速度。从上面这句话来看,应该也不能提高速度。但是从这里得到提示,自己试了试看,确实速度提高了不少,如下所示:

 

        但是又神奇地从这里看到一句话:matlab会对double类型做运算的时候做加速,应尽量避免使用single。

       天呐,我彻底崩溃了,到底哪句是真的?至少从实验结果来看,single要比double快。而int类型没法用tic toc统计时间,我也没实验,理论上应该会更快。

        那到底这句红色的英文是啥意思啊?求指教。

        ------写完此文发现,人家那句话指的是format命令.......用上面的强转,就没这个事了吧。哎,阅读水平真烂.....

 

Tips

1.    Matlab中如果我们使用循环的话,如果循环体内的程序不含有single等类型,而且使用的函数都是matlab的build-in function的话,matlab会自动帮助你优化for循环。

2.    使用ctrl + i 可以对选中的代码区域自动排版。


 

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

matlab中double 和single数据类型的差别

matlab中double 和single数据类型的差别 double数据类型占用8个字节,single数据类型占4个字节。所以用single会更快一些。(可以这么理解,就像你做8位数乘法跟做4...

MATLAB之single函数

MATLAB之single函数: 一般来说,大矩阵计算,如果用single类型的数据能节省一半的内存空间,matlab在内部执行的时候是默认转换成double类型进行运算,据说可以从菜单里面改设置变成...

matlab大数据计算技巧(持续更新中)

在matlab中, 当数据比较大时,运算起来就困难了,有时候还会out of memory(例如4000*4000的矩阵,要算矩阵乘法都比较吃力)。此文会记录我学到的一些解决办法:   1. 将数...

matlab中用imshow()显示double类型图像中出现的问题

在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算。在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从unit8型变成double型。如果...

matlab图像类型转换以及uint8、double、im2double、im2uint8和mat2gray等说明

1. matlab图像保存说明  matlab中读取图片后保存的数据是uint8类型(8位无符号整数,即1个字节),以此方式存储的图像称作8位图像,好处相比较默认matlab数据类型双精度浮点doub...

MATLAB图像类型转换以及uint8、double、im2double、im2uint8和mat2gray等说明

今日在用MATLAB放大图像的时候踩到一个坑,本来想着放大至两倍之后,输出图像中每4个点对应原来一个点,结果用 `imshow` 显示一片空白,非常郁闷。上网找答案未果,之后偶然发现类型不同,原来的是...

matlab编程中涉及到图象矩阵数据类型uint8\double matlab中用imshow()显示图像与图像矩阵的数据类型

记得当时用 imshow 显示灰度图有一些问题 进行double转化后解决 这个问题是在刚开始接触使用Matlab处理图像时经常会遇见的困惑。         网上有这么一种说...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)