如何提高MATLAB的运算速度

  • Post author:
  • Post category:其他




将提高MATLAB运算速度的途径总结为以下几点:



1. 硬件方面:CPU配置高一些;



2. 利用Profiler评估程序,查找出函数花费时间较多的地方优化;



3. 尽量少使用for或者while循环,而是向量化;



4. 循环中,尽量将变量预配置,即预先开辟空间,减少循环内部的动态配置;



5. 尽量使用MATLAB函数库中的自带函数;



6. 尽量将需实现的独立功能编写成M函数,尽量少用M脚本文件;



7. 将程序进行编译,MEX文件,进行执行;



8. 可以考虑利用并行计算Parallel,前提是脚本可以进行并行计算,具体查看:help parallel



9. 在脚本可以并行计算的前提下,将可以利用的计算机搭建并行集群,建立并行环境。



如何启动MATLAB并行计算?



以单台双核计算机为例。首先打开MATLAB命令窗口,输入matlabpool open就OK了。如图所示:



  1. 这样,就相当于将一台计算机的两个核心,当做两台机器用啦。接下来是编程序实现的方法。


  2. MATLAB并行计算的模式有几种?


    主要是两种:parfor模式和spmd模式。两种模式的应用都很简单。第一个中,parfor其实就是parallel+for简化而来,顾名思义啊,就是把原来程序中的for循环中的关键字forg改为parfor就OK啦。不过这是很初步的介绍,限于篇幅不能详细展开了,详细的可以用输入命令help parfor查看,如图:


  3. 同样地,可以适用于spmd模式。


  4. 程序举例:例如很简单的一个程序:


    tic


    %传统方式计算


    c1=1;


    for i = 1:500


    c1 = c1+max(eig(rand(i,i)));


    end


    t1 = toc;


    matlabpool open;


    %parfor并行方式计算


    tic


    c2=1;


    parfor ii = 1:500


    c2 = c2+max(eig(rand(ii,ii)));


    end


    t2 = toc;


    matlabpool close;


    display(strcat(‘parfor并行计算时间:’,num2str(t2),’秒’));


    display(strcat(‘客户端串行计算时间:’,num2str(t1),’秒’));


    分别用传统方式算和parfor算,时间区别如下图所示:


    这只是用双核计算的效果,如果是4核心8核心,效果要好的多啦,需要用MATLAB的童鞋不妨试试看咯。


  5. 关闭并行计算模式。


    不想用了?送一个命令进去就关了,估计你已经猜到那即是:matlabpool close.如图所示: