使用profile功能对Matlab性能调优
来源:互联网 发布:淘宝导航图片怎么放 编辑:程序博客网 时间:2024/05/16 04:51
做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了!
0 0
- 使用profile功能对Matlab性能调优
- Matlab的Profile功能
- Matlab的Profile功能
- 【性能分析】初探VS2010中的Profile(性能剖析)功能
- 【性能分析】初探VS2010中的Profile(性能剖析)功能
- matlab profile
- Matlab 实现对码功能
- MySQL性能分析工具profile使用教程
- Unity 使用Profile查看真机性能
- mysql使用profile分析语句性能消耗
- MySQL性能分析工具profile使用教程
- 飘逸的python - 性能调优利器profile及其意义
- 初探VS2010中的Profile(性能剖析)功能
- 关于使用 QEMU 对系统进行 profile
- matlab绘图功能的使用
- 使用mysql profile精确找到sql性能缺陷
- MySQL性能分析工具profile的使用(1)
- MySQL性能分析工具profile的使用(2)
- VS生成事件的使用
- android捕获ListView中每个item点击事件
- hdoj2070 Fibbonacci Number
- 从米4发布会,总结雷军的十大产品观
- hdu 1175 连连看
- 使用profile功能对Matlab性能调优
- flume学习(三):flume将log4j日志数据写入到hdfs
- 开源夏令营(2)
- STL vector实现
- 【移动】chrome浏览器模仿移动浏览器效果
- cocos2dx学习笔记(CCHttpRequest和CURL两个方式)
- HDU 2003 求绝对值
- MySQL 索引优化 Using where, Using filesort
- listview中增加checkbox导致item点击事件失效