多开MATLAB并行计算

简介

有时遇到MATLAB计算量较大且耗时的重复性劳动计算时,可以利用MATLAB的并行工具箱,也可采用多开MATLAB的方式,并行计算。

方法

MATLAB可以调用dos,然后让dos多开MATLAB,进而实现MALTAB自动化控制多个子MATLAB运行,而且还可以利用MATLAB与MATLAB之间的消息传递方法,例如读写文本的形式传递消息,参见利用读写文本实现MATLAB应用之间的消息传递,实现多个MATLAB并行计算并相互沟通协调运算的情况。

实现

该函数可以同时开启多个MATLAB,并控制每个MATLAB按照顺序运行对应的m文件。
输入参数:
user_folder:每个MATLAB的运行工作路径
MFileList:MATLAB运行的m文件,每个MALTAB运行其中一个
t_delay :可不输入,默认为1s,开启MATLAB的延时

function run_mpi_mfiles( user_folder, MFileList, t_delay )
if nargin < 3
    t_delay = 1;
end
for i = 1:numel( MFileList )
    dos( [ 'start ', ' matlab.exe -nosplash -nodesktop -r cd(''', user_folder, ''');', MFileList{ i } ] );
    disp( [ 'executing file ', num2str( i ) ] );
    pause( t_delay );
end
end

总结

利用MATLAB 调用 dos ,可以同时运行多个MATLAB,可以尽可能使用电脑的性能,加快不相关的多个重复程序并行运行。

你可能感兴趣的:(MATLAB,matlab)