Speeding up a load file workflow
3 ビュー (過去 30 日間)
古いコメントを表示
I'm working with a program that outputs simulation to results to many .mat files. To analyze these results, I need to load each of these mat files. Currently, I use the following lines to do this.
for i = 1:numFiles
cases{i} = load(files(i).name);
end
after preallocating the cases cell array, of course. The problem is, repeatedly using the load function like this can drastically increase the time I need to analyze my results, depending on how many mat files this program outputs.
My question, then, is this: Is there any way to load multiple files at once?
Thanks!
0 件のコメント
採用された回答
Swastik Sarkar
2024 年 11 月 22 日
I know of 2 options to load the MAT-files faster, both of which will require the Parallel Computing Toolbox.
One approach is to utilize the parfor loop to load MAT files in parallel on separate workers:
parfor i = 1:numFiles
cases{i} = load(files(i).name);
end
Another approach is to use the parfeval function to create futures and wait for them asynchronously:
for k = 1:numFiles
futures(k) = parfeval(@load, 1, files(k).name);
end
for k = 1:numFiles
[idx, loadedData] = fetchNext(futures);
cases{idx} = loadedData;
end
Hope this helps load MAT-files faster.
2 件のコメント
Walter Roberson
2024 年 11 月 22 日
Other than Parallel Computing Toolbox, and Background Pools, there is no way to load multiple files simultaneously.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Programming Utilities についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!