sharing matrix in parfor

I have a program which uses the parfor loop and contains a large matrix (2-3GB). Each worker continuously access random locations in the matrix, but never write to the matrix. When using parfor the matrix is copied for each worker causing a massive memory spike. Is there a way to prevent this and allow each worker to read from the same matrix?

回答(1 个)

Sarah Wait Zaranek
Sarah Wait Zaranek 2012-9-14

1 个投票

There is no way to do shared memory automatically in a parfor loop. However, depending on where the data is located - there may be options. For instance, if the data is coming from a file - memory mapping may work well. Look at the function memmapfile.

类别

帮助中心File Exchange 中查找有关 Parallel for-Loops (parfor) 的更多信息

提问:

2012-6-30

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by