Parallel ODE solve using parfor-loop
12 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Hello, I've got the ODE system and want to solve it using the cluster. I've been trying to use parfor-loop, but the initial condition must be changed for every new call of ode-solver. And the results I received isn't correct. Maybe there are some build-in tools for such problem? Here is my attemp to parallel ode solving
parfor i=1:100
[T,X]=ode45(@rightpart,[i*500-499 i*500],X0,options);
%each worker will calculate values for T from 1-500,501-1000 and so on
Tt=cat(1,Tt,T);
Xt=cat(1,Xt,X);
%here I accumulate final value vectors
end
1 Commento
Ryan G
il 13 Mag 2013
PARFOR works by sending independent calls of the loop to each member of the pool. If your next call to the solver is dependent on a previous call, this will not work.
The cat function here will randomly order the data based on whenever the next iteration comes in. I would recommend indexing here instead.
Risposta accettata
Jan
il 14 Mag 2013
Do all integrations start at the same X0? If not, is the final value of the former integration the initial value of the current interval? If so, the job cannot be parallelized.
As Pyan G has explained in his comment, concatenating the output inside the PARFOR loop will cause a random order: The output depends on the exact timining of the single jobs. This could be fixed by storing the partial results in a cell like C{i}.
Più risposte (0)
Vedere anche
Categorie
Scopri di più su Parallel for-Loops (parfor) in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!