Can we use 'parfor' in user defined function?

Hello, Can we use 'parfor' in used defined functions? I want to use parfor in user defined functions to improve the speed of my code but its not working. Is there any way we can use it?

3 Commenti

What function you are trying to use parfor?
any user define function for example
% code
y=function_name(p);
% called function
function y=function_name(p)
parfor k=1:10
y=p+k
end
end
That use of parfor is not permitted because the output would depend upon which iteration ran last. You need either assign to an indexed variable or you need to use a reduction variable (for example totaling the values of the individual iterations)

Accedi per commentare.

 Risposta accettata

Walter Roberson
Walter Roberson il 6 Ago 2017
Yes, for sure you can, provided that you have the parallel computing toolbox installed and licensed

4 Commenti

Thank you so much.
I have parallel computing toolbox installed but still its not working, may be I don't know how to handle parfor in called functions. Would you give me a simple example of a code?
function y = function_name(p)
t = 0;
parfor k = 1 : length(p)
t = t + p(k);
end
y = t;
end
Thank you so much

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Loops and Conditional Statements in Centro assistenza e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by