Alternatives to break command inside a spmd command

5 vues (au cours des 30 derniers jours)
Daniel Jaló
Daniel Jaló le 16 Fév 2013
Commenté : John Nwankwo le 15 Nov 2018
Hello. I was looking for an alternative to a break command inside an spmd block. Imagine we have a code with 4 loops in parallel, one for each lab. I want all the loops to stop when one condition is met. Now, whichever lab has the condition met will simply stop the loop by means of a break command. The other labs however will not know that the condition has already been met and will continue running. I want to find a way for they all to get out of the loop.
I thought about using the labSend/labReceive commands to warn the remaining labs that the condition has already been met. The problem is that for the other labs to receive it that would require me to put an additional condition in each lab, of the kind
if labReceive==1
break
end
The problem is that this conditions would require the labs to communicate to some degree every iteration, and I'm afraid that it will considerably slow my code...
Will the code get significantly slower? Are there other alternatives for me to stop all the loops?
Thanks. Cheers.

Réponses (1)

Konrad Malkowski
Konrad Malkowski le 21 Mar 2013
What you will need to implement is a parallel termination detection algorithm.
See the following link for references:
  1 commentaire
John Nwankwo
John Nwankwo le 15 Nov 2018
There is no information on your link

Connectez-vous pour commenter.

Catégories

En savoir plus sur Data Distribution Plots dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by