matlab的内存管理
来源:互联网 发布:单片机控制led灯 编辑:程序博客网 时间:2024/05/22 14:23
用 Matlab 进行大规模科学计算或仿真时,内存是一个需要时常注意的问题。当你写的 Matlab 程序跳出“Out of Memory” 时,以下几点措施是需要优先考虑的解决方法:
1. 确保内存的连续性 Matlab 中数组必须占用连续分配的内存段,当无法为新建的数组分配连续的内存段的时候,”Out of Memory” 就会出现。由于反复分配和释放数组会使可用的连续内存段减少,因此当 Matlab 刚刚启动时其连续内存最多,此时往往可以新建非常大的数组,这一点可以用命令 feature(’memstats’)(在 7.0 版本以上)看出。如果现实的最大连续内存段很小,但实际可用内存(非连续的)仍旧很多,则表明内存中碎片太多了。此时可以考虑用 pack 命令,pack 命令的作用就是将所有内存中的数组写入硬盘,然后重新建立这些数组,以减少内存碎片。此外,在命令行或者程序中都可以使用 clear 命令,随时减少不必要的内存。
2. 3GB 开关 由于32位 Windows 操作系统的限制,每个进程只能使用最多 2GB 的虚拟内存地址空间,因此 Matlab 的可分配内存也受到相应的限制。Matlab 7.0.1 引进了新的内存管理机制,可以利用 Windows 的 3GB 开关,使用 3GB 开关启动的 Windows 每个进程可以在多分配 1 GB 的虚拟地址空间,具体的操作方法可见:http://www.mathworks.com/support/tech-notes/1100/1106.html
3. 减少使用双浮点数 Matlab 默认的数字类型是双精度浮点数 (double),每个双浮点数占用 8 个字节。对于一些整数操作来说,使用双浮点数显得很浪费。在 Matlab 中可以在预先分配数组时指定使用的数字类型如以下命令:zero(10, 10, ‘uint8′) 。对于浮点数,在很多精度要求不高的情况下,可以使用4个字节的单浮点数 (single),可以减少一半的内存。关于单、双浮点数的精度对照如下,以便根据需要选择使用:
single: 精度 (1.1921e-007) 最大数 (3.4028e+038)
double: 精度 (2.2204e-016) 最大数 (1.7977e+308)
- matlab的内存管理
- Matlab 的内存管理
- Matlab 内存溢出的管理方法
- matlab内存管理
- matlab内存管理(二)
- MATLAB内存管理
- Matlab 内存管理
- MATLAB内存管理
- [转载]MATLAB内存管理
- Matlab 内存管理
- Matlab内存变量管理命令
- Matlab的内存问题
- Matlab的内存分配
- 关于matlab高效管理内存的方法,进而降低Out of Memory出现的机率
- Matlab 的内存分配机制
- matlab扩大内存的方法
- MATLAB内存溢出的解决办法
- Matlab 的内存分配机制
- SOA框架的六个缺陷和两个难题
- TThreadList 的用法
- 我的第一个音频文件
- SAP-WM标准教程LO140阅读体会(2)
- 链队列
- matlab的内存管理
- 请问你觉得生产静态页面一点意义都没有吗?
- SOA架构暴露固有缺陷 CIO应时刻保持警惕
- Hibernian 同一事物提交三个表
- 大学时代影响我的人生的10件大事-前辈的经验
- VC获取系统时间、程序运行时间
- 每周公布病情 - 北京18区县均有手足口病例
- XSL:XSL基础之十
- 简明x86汇编语言教程