Profile(分析)

在加速你的matlab程序之前,你需要知道你的代码哪一部分运行最慢。matlab提供个简单的机制,让你能够知道你

的代码的某一部分运行所占用CPU时间。通过在代码段开始添加tic,及在结束添加toc;matlab就能计算出这一代

码段的运行时间。

Tic和toc方法存在两个问题:

(1)显示的时间是运行时间“wall clock”。这个时间受你在运行你的代码时,你的计算机是否同时运行其它别的程

序。

(2)你需要不断地压缩计时范围来查找你代码运行最慢的位置。

一个最好的方法是利用matlab 内嵌的代码分析器。在你的程序前面通过添加命令profile on;及在程序结束添加

profile viewer;并运行你的程序。当程序正常运行结束时,代码分析器窗口将弹出,并显示分析结果。它包含的信息

有:

Function Name :函数名;

Calls :函数被调用次数;

Total Time :执行该函数的CPU总用时,包含任何其它被它调用的函数的CPU时间。

Self Time :执行该函数的CUP总用时,不包含任何其它被它调用的函数的CUP时间。

Total Time Plot :时间用时的曲线图。

以上信息可进行各种排序和详细查看。

注意:当你完成你的代码分析后,请删除profile on和profile viewer,因为嵌入代码分析器会使用的程序运行变慢。

标准提示

有问题找帮助文档。学会使用帮助文档,学会针对待解决的问题检索文档资料。

☆性能

查看MATLAB->Programming->Improving Performace and Memory Usage;或MATLAB->Programming

Fundamentals->Performace->Techniques for Improveing Performace。

多线程

如果你使用的是多核心的计算机,那么你就可以让Matlab同时运行多个线程,Matlab程序中一些底层的函数

(Low-level function)就有可能采用并行计算的方法。打开多线程的方法:File->Preferences选择General->

Multithreading。扣选Enable multihread computation box。如果不限制使用核心的数目,可以保留使用Automatic。

注意:Matlab R2008a之前的版本在AMD处理器上是不支持多线程的。

向量化循环

Matlab的运算是针对向量(矢量)和矩阵进行设计的,因此它在向量和矩阵上的运算速度比采用循环的方式更快。

例如:

index=0;

for time=0:0.001:60;

index=index+1;

waveForm(index)=cos(time);

end;

采用以下代码可加快速度。

Time=0:0.01:60;

waveForm=cos(time);

一些有用的,可用于代替循环的函数:

any();size();find();cumsum();sum();

向量预分配

Matlab采用内存中一块连续的空间来存储向量和矩阵数据,而不是用链表。这就意味着你每给向量或矩阵增加一元

素,Matlab需要寻找一块足够大的内存区域来存储这个扩大后的向量或矩阵,然后复制现有的数据到新的内存区

域。在循环中增加向量或矩阵元素的元数是允许的,但并不是明智之举,而应该是一次性分配向量或矩阵的大小,

或一次性重定义尺寸。

Results=0;

for index=2:1000;

results(index)=results(index-1)+index;

end

上述代码将比以下代码速度慢:

results=zeros(1,1000);

for index=2:1000;

results(kindex)=results(kindex-1)+index;

end;

注意:当你需要用zeros()来创建一个指定数据类型的向量或矩阵时,你可以使用创建参数来指定类型,而不是“重

铸”。results=int8(zeros(1,1000));将创建一个有1000个元素的double型零向量,然后把它转换成int8类型。如果我

们使用results=zeros(1,1000,'int8'); Matlab将支持建立1000个int8类型的向量,在创建可实现性及速度上将更具有

优势。

不要改变数据类型

Matlab为了能够支持宽松的数据类型(例如一个变量能够存储不同类型的数据,而不是指定它为特定的数据类

型),则Matlab除了存储单纯的数据之外,还需要伴随数据存储一定数量的头信息(header),这就意味着需要内

存空间支存储数据类型,同时意味需要在数据类型转换上支付额外的计算机资源开支。

对于实数据使用 real...函数。

Matlab中的一些函数能够同时适用于实类型数据和复类型数据。如果你只使用实数据,那么采用特定的版本的,非

复数据函数,那么它运行的速度将变得更快。这些函数如:reallog(), realpow(),realsqrt()。

使用“短路”逻辑操作

Matlab的“短路”逻辑操作可以在判断条件达到充分条件后就停止计算处理,而不需要知道判断所有条件。例如:if(index>=3)&&(data(index)==5); 当index小于3时,第二个条件判断将不被处理,这样就少了去判断

data(index)==5)的时间,提高速度。

使用函数指针

Matlab的一些函数使用函数名作用参数,常用一个变量支保存这个函数名字符串()如:func='tan';然后用这个

变量作为函数的参数:fzero(func,0))。这种方法对于简单的函数调用是很好的,但是对于在循环中的重复调用就

存在两个问题:

(1)在每一个循环中,Matlab需要去搜索这个函数的路径(如tan),这需要花费时间。

(2)在循环过程中,路径可能会改变。这会保证在这一次循环中,某个版本的函数(如tan)被首先调用,而下一次

循环中这个版本的函数又被首先调用,最终会造成结果不一致。

解决的办法是使用文件指针(;或func=@sin),它能返回函数唯一的识别码。调用方式同上。

文件I/O

通常高级输入输出操作(load()和save())比一般的低级操作(fread()和fwrite())快。

☆内存使用

关于内存的使用可查看帮助文档Using Menory Efficently。可查与Memory Usage相关的信息。

一定记注:可以使用whos()来查看数据变量占有用的内存空间大小。

复制数组

当你复制一个数组时,Matlab开始只复制一个指向数据的一个指针,仅当你随后对任一版本进行修时,数据的复制

才真正的执行。这种操作包括数组作为函数参数进行传递的情况-作为值传递的参数传递,而不是作为参考的传

递。因此,你应该尽量避开对大数组进行小改动的操作。

数据不用时,释放内存

如果一个变量以后已经不再使用,那么你可以删除它clear VariableName;则这个小块的数据将可以重用。

注意:如果各变量在内存是连续的,则Matlab很容易重用这些大块的内存,因此最好是先建立大的变量,后再建立

小的变量,并且把它们组合起来。

结构体存储

上文已经提到,在Matlab中的变量包含有描述数据类型的头信息。对于一个结构体,则有一个描述整个结构的头信

息,及每个元素也分别有一个头信息。为了最小化地使用内存,我们应该小心地使用混合数据类型的数组和结构。

例如:

pixel.red(1:600,1:400)

pixel.grn(1:600,1:400)

pixel.blu(1:600,1:400)

则我们就需要存储4个头信息。而:

pixel(1:600,1:400).red

pixel(1:600,1:400).grn

pixel(1:600,1:400).blu

我们就有720001个头信息。

使用最小的合适的数据类型

为了减小内存使用量,对于特定的运算经常使用最小的数据类型。例如:

(1)对于虚部为零的数据,最好不要用complex去存储。

(2)如果精度足够,可采用single变量,而不用double。

(3)使用uint16来进行计数操作,它能存储值为0到65535。但它比默认的double型省一半的内存。

使用稀疏矩阵

如果矩阵绝大多的数据为零值,可以把它转化成稀疏形式(使用sparse()函数)。它将只存储非零数据的数值和索

引。因为需要额外的存储数据的索引,因此只有二维数据的零值大约超过75%时,这种方法才是有效的,否则稀

疏形式反而需要更多的内存空间。

☆并行循环

如果从一个for循环的外部看,for循环满足以下标准:

(1)循环的计数是整数;

(2)每次循环都是独立的;

(3)计算循环先后顺序无关。

那么这个for循环就有可能可以替换成parfor循环(matlab2008a中可用优化算打开并行通信池:parfor循环包含于

matlabpool open 和matlabpool close之间)。

注意:打开一个并行工作池worker pool大约需要10-15秒钟,关闭一个工作池大概需要5秒钟。计算这个时间在

内,这个方法对于循环时间超过30秒的情况才是值得的。

Matlab代码的耗时分析、优化、加速相关推荐

  1. ADMM,ISTA,FISTA算法步骤详解,MATLAB代码,求解LASSO优化问题

    ADMM,ISTA,FISTA算法步骤详解,MATLAB代码,求解LASSO优化问题 原创文章!转载需注明来源:©️ Sylvan Ding's Blog ❤️ 实验目的 了解 ADMM, ISTA, ...

  2. MATLAB代码:基于双层优化的电动汽车日前-实时两阶段市场竞标

    MATLAB代码:基于双层优化的电动汽车日前-实时两阶段市场竞标 关键词:日前-实时市场竞标 电动汽车 双层优化 编程语言:MATLAB平台 参考文献:店主自编参考文献,可联系我查看 内容简介:代码主 ...

  3. dijkstra算法matlab代码_头脑风暴优化(BSO)算法(附MATLAB代码)

    BSO讲解https://www.zhihu.com/video/1252605855767736320 B站搜索:随心390,同步观看视频 各位小伙伴可在闲鱼搜索 优化算法交流地,即可搜索到官方闲鱼 ...

  4. a*算法matlab代码_NSGAII多目标优化算法讲解(附MATLAB代码)

    小编今天为大家讲解NSGA-II多目标优化算法,提到多目标优化,大家可能第一个就想到NSGA-II算法,今天小编就带领大家解开NSGA-II的神秘面纱. NSGA-II全称是快速非支配排序遗传算法,这 ...

  5. 加权贝叶斯matlab代码,使用贝叶斯优化进行深度学习

    准备数据 下载 CIFAR-10 数据集 [1].该数据集包含 60,000 个图像,每个图像的大小为 32×32,并具有三个颜色通道 (RGB).整个数据集的大小为 175 MB.下载过程可能需要一 ...

  6. Android设备安装150个应用后开机耗时分析优化

    设备安装150个应用后,开机耗时增加7s,主要是PMS扫描/data/app,耗时6.5s. 分析发现,主要耗时在 scanPackageNewLI 解析apk文件 commitReconciledS ...

  7. Python代码cProfile耗时分析及可视化

    Python: cProfile 食用方法 import cProfile# 直接把分析结果打印到控制台 # loading为需要监测的函数,arg为其参数 cProfile.run("lo ...

  8. 多目标优化 | NSGA-Ⅲ(中篇,附MATLAB代码)

    目录 常规归一化操作 种群个体的自适应归一化操作 计算种群理想点 转换种群目标函数值 计算每个坐标轴对应的极值点 计算超平面与坐标轴的截距 归一化种群目标函数值 种群自适应归一化操作伪代码 NSGA- ...

  9. 金豺优化(GJO)算法(含MATLAB代码)

    先做一个声明:文章是由我的个人公众号中的推送直接复制粘贴而来,因此对智能优化算法感兴趣的朋友,可关注我的个人公众号:启发式算法讨论.我会不定期在公众号里分享不同的智能优化算法,经典的,或者是近几年提出 ...

最新文章

  1. Intel汇编程序设计-整数算术指令(下)
  2. 基于 Kotlin 一行代码实现 android 导航栏 BottomBar
  3. 七、度量数据的相似性和想异性
  4. go语言调用python_Golang中调用Python3
  5. Java集合系列---红黑树(基于HashMap 超详细!!!)
  6. java充血模型orm框架,关于领域驱动设计和贫血、失血、充血模型
  7. java url工具_UrlTool官方版|UrlTool (java Url转换工具)下载v1.1-乐游网软件下载
  8. ActionScript 3.0编译器编译错误大全【转】
  9. Adobe 全家桶关闭自动更新?技巧来啦!
  10. python微信语音转发方法_最简单的微信语音转发方法,保证看一遍就会
  11. Spring实例(DI注入)——女生追男生
  12. SpringBoot html转pdf 支持中文、图片水印+文字水印、页眉页脚 flying-saucer-pdf-itext5 + freemarker
  13. 老司机珍藏的130个网站,没人的时候偷偷看!
  14. base64编码和解码的js工具函数
  15. 以太坊学习笔记(一):基于POA的私有链搭建
  16. 双系统下ubuntu自动挂载windows盘
  17. 3.后端学习JavaScript
  18. 信息安全专家李钊博士:信息物理系统安全措施
  19. 怎么将PPT里面的普通文字设置成艺术文字
  20. Liferay 学习教程-ServiceBuilder的基本使用

热门文章

  1. mysql排插问题_MySQL一次数据插入故障记录
  2. 【渝粤教育】电大中专幼儿园课程论 (7)作业 题库
  3. [渝粤教育] 中国地质大学 操作系统原理(新) 复习题
  4. [渝粤教育] 西南科技大学 畜牧概论 在线考试复习资料
  5. 转hdmi_苹果本轻松接大屏,毕亚兹雷电接口转HDMI/VGA转换器评测
  6. php提前用户系统时间限制,php date()比服务器时间提前一小时(DST问题)
  7. 【MFC系列-第24天】梯形分页和蝴蝶QQ宠物的实现
  8. Java简单内存解析
  9. 打开服务器文件提示内存不够,打开服务器文件提示内存不够
  10. esp32搭建文件服务器,ESP32入门示例 - SD卡Web服务器