10
votes

Have a simple question about parfor in MATLAB. I would like to set a flag in my program to change between parfor and regular for loops. Basically, I need this functionality so that some parts of my code can update graphics in a "debug" mode, then when the flag is turned off, use parfor with no graphics updates for speed.

So, I'm looking for something simple that has this functionality:

if (flag)
  for i = 1:n
else
  parfor i = 1:n
end

  % Do loop tasks.

  end

Any help would be greatly appreciated! Thanks!

3
Does reserving a pool size of 1 solve your problem?Mikhail
Not exactly because parfor restricts creating any graphical objects, such as plots. Therefore, whenever I desire this output, I have to manually edit the code of the function.Kyle Lynch

3 Answers

6
votes

No, this is not possible. However, if you can wrap the loop body in a separate function, you can have either a parfor or a for loop call the body, i.e.

if (flag)
   parfor i=1:n
      out(i) = loopBody(i)
   end
else
   for i=1:n
      out(i) = loopBody(i)
   end
end

Alternatively, you can edit the code so that you have either parfor or for in front of your loop, which is what I often end up doing.

6
votes

One more option - use the optional argument to PARFOR

if flag
  arg = Inf;
else
  arg = 0;
end
parfor (idx = 1:n, arg)
   ...
end
5
votes

When you close the pool by matlabpool close, parfor behaves just like a for and allows all graphics handling. So you just need to close the pool while debugging.