PARFOR in real applications
Afficher commentaires plus anciens
I've installed the Parallel Computing Toolbox for some experiments with my code. To my surprise none of the codes run faster with PARFOR compared to sequential FOR loops.
Examples:
- https://www.mathworks.com/matlabcentral/answers/762196-how-can-i-efficiently-add-multiple-arrays-generated-in-a-loop
- Another example was a simple loop calling the external lame.exe function:
lamebin = 'C:\Program_\lame3.99.5\lame.exe';
switches = ' -m j -h -V 1 -q 2 --vbr-new --nohist';
WavFiles = dir(fullfile(Folder, '*.wav'));
parfor iWav = 1:nFile
aFile = fullfile(Folder, WavFiles(iWav).name);
[aPath, aFile] = fileparts(aFile);
aMP3 = fullfile(aPath, [aFile, '.mp3']);
[s, w] = dos([lamebin, switches, '"', aFile, '" "', aMP3, '"']);
end
Both examples take about the double time than a FOR loop on my 2 core CPU, but there is no acceleration on the 4 core also. The RAM is not exhausted in both cases.
Questions:
- Are there obvious mistakes in my naive approachs?
- How do you use PARFOR in your applications to accelerates the processing on a pool with 2 or 4 local workers? I know the examples from the documentation, but I was not successful yet to implement it in my codes.
4 commentaires
Mario Malic
le 4 Mar 2021
Modifié(e) : Mario Malic
le 4 Mar 2021
Hi Jan,
At least on Windows, I have no problems with parfor when I run this. If your program creates some temporary files, it would be also good to consider WorkingDirectory within StartInfo so workers and programs do not cause some issues with each other.
exeProcess = System.Diagnostics.Process;
exeProcess.StartInfo.Arguments = '-example arguments';
exeProcess.StartInfo.FileName = lamebin % full file path
exeProcess.Start();
Does your program utilize all cores already with its single instance?
Jan
le 4 Mar 2021
Mario Malic
le 4 Mar 2021
Approximately, how long does take for one run of your program?
Edric Ellis
le 5 Mar 2021
I presume when you're trying with Java you are running multiple "lame" processes simultaneously, and seeing a sensible speed-up? (I was going to speculate that perhaps disk access was limiting performance, but if you're able to get expected performance running multiple processes a different way, then that would seem unlikely).
Réponses (1)
Jan
le 16 Mai 2022
0 votes
Catégories
En savoir plus sur Parallel for-Loops (parfor) dans Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!