MATLAB Answers

Global variables in parfor loop

105 views (last 30 days)
Abhinav
Abhinav on 29 Jun 2018
Commented: Abhinav on 29 Jun 2018
I am using global variables in parfor loop and I get following m-lint
The code uses a global variable in a parfor loop. Because parfor loops run on several different machines simultaneously, the global workspace might not be the same on each machine. Therefore, using a global variable in a parfor loop could have unpredictable or unexpected results and Code Analyzer flags it as an error.
This is my code:
r=cell(size(sample,1),1);
parfor samp=1:size(sample,1)
theta_opt=theta_opt_array(samp,:);
Cp_opt=diag(Cp_opt_array(samp,:));
beta_opt=beta_opt_array(samp);
sigmaobs2_opt=sigmaobs2_opt_array(samp);
mu=strm(:,samp);
n=10000;
Ct_opt=CovarianceMatrixEstimation(Cp_opt,theta_opt,sigmaobs2_opt,...
GLOBAL_DATA,GEOMORPH); % these two are global variables
r{samp}=mulgennormrnd(n,mu,Ct_opt,beta_opt);
end
Any suggestions on how to fix it? I don't understand the suggested fix by MATLAB. The suggestion by MATLAB is:
Make local copies of the global variables that you want to use within the parfor loop before beginning the parfor loop
Also,I am not changing my global variables in parfor loop.

Accepted Answer

Adam Danz
Adam Danz on 29 Jun 2018
Edited: Adam Danz on 29 Jun 2018
What was the suggestion by Matlab? Have you read through the plethora of answers to this topic?
There are lots of reasons not to use global variables at all and this is one of them. As the error message indicates, parfor() is executed in parallel potentially between >1 machine. Global variable are not accessible between machines. So you'll have to initialize them independently within your code.
  6 Comments
Abhinav
Abhinav on 29 Jun 2018
yes, the output of covarianceMatrixEstimation is used in same iteration, not cross-iteration. Thanks a lot for your suggestion!

Sign in to comment.

More Answers (0)

Products

Community Treasure Hunt

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

Start Hunting!