使用profile功能对Matlab性能调优

Matlab性能优化:利用profile功能
本文介绍了如何使用Matlab的profile功能进行性能调优。通过对比function在不同m文件和同一m文件中的运行时间,发现addpath函数的大量调用是导致运行时间增加的主要原因。删除多余addpath并优化后,运行时间显著减少,但仍然体现出调用多个m文件的开销。profile功能被赞誉为强大的性能分析工具。
部署运行你感兴趣的模型镜像

做PCANet的时候,Matlab抽风,加不了断点,无奈之下只好把所有的function都写到了一个m文件里。结果发现所有function写在同一个m文件下时,程序运行速度快很多。

后来师兄告诉我,用Matlab的profile功能可以查看程序各个函数的运行时间,这样就能找到原因所在。我尝试了一下,profile真是炫酷得不行。使用pfofile的代码如下:

profile on;
profile clear;
my_binary_net(1);%我的运行函数
profile viewer;

然后就会一个窗口出来,这个是我把所有function放在一个m文件时候的运行时间:

下面这幅图是我程序的function分开在不同m文件时候的运行时间:


通过这两个图可以发现造成时间大幅增加是因为addpath函数。这是因为,当我运行的程序的function在不同m文件时,我调用的很多function都包含addpath语句,于是matlab足足调用了22613次addpath。而我运行程序的function在同一个m文件时,我把多余的addpath语句删了,只在程序开头添加了addpath。

既然已经真相大白了,我把其他m文件的多余addpath语句删掉,再运行一次,结果如下:


这次就比上次用时少了500多秒。但还是比所有function写在一个m文件要多出200多秒,可以看出调用m文件也是要耗费很多时间的,但把不同函数写在不同m文件有助于代码复用,是良好的编程规范,没必要为了节省这点时间而把代码全部写在一个文件里。

最后再次发表一下感慨,profile真是个无比强大的功能!以后再也不用tic toc了!


您可能感兴趣的与本文相关的镜像

Anything-LLM

Anything-LLM

AI应用

AnythingLLM是一个全栈应用程序,可以使用商用或开源的LLM/嵌入器/语义向量数据库模型,帮助用户在本地或云端搭建个性化的聊天机器人系统,且无需复杂设置

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值