For loop in parfor loop
    6 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Niels
 el 10 de Mzo. de 2015
  
    
    
    
    
    Comentada: Niels
 el 10 de Mzo. de 2015
            Dear all, I am trying to run the following script
a = linspace(0,10);
parfor ii=1:2
   for jj=1:length(a)
      x(ii,jj) = rand;
   end
end
which fails with an "Error: The variable x in a parfor cannot be classified." Is this a bug in Matlab? I would simply consider the vector "a" a broadcast variable, since "a" and "length(a)" are unmodified by the script.
How would you recommend to fix the script, taking into account that length(a) should be evaluated inside the parfor loop?
Thanks, Niels
0 comentarios
Respuesta aceptada
  Greig
      
 el 10 de Mzo. de 2015
        I don't know the details (perhaps another answer can get technical), but parfor loops don't like assigning values to things like x(ii, jj) directly, so you have to use temporary variables that are accessed only in the parfor loop. Try something like this....
a = linspace(0,10);
x=NaN(2,length(a)); % pre-allocated for speed
parfor ii=1:2
      tmp_var=NaN(1,length(a)); % pre-allocate a temporary variable
      for jj=1:length(a)
          tmp_var(jj) = rand;
      end
      x(ii,:) = tmp_var; % assign it to x
end
0 comentarios
Más respuestas (1)
  Edric Ellis
    
      
 el 10 de Mzo. de 2015
        
      Editada: Edric Ellis
    
      
 el 10 de Mzo. de 2015
  
      The limitation you're hitting here is that any for loop nested inside a parfor loop must have constant bounds to allow slicing. In your case, the bounds are constant, so you can simply write:
a = linspace(0,10);
n = length(a); % extract length outside PARFOR
parfor ii=1:2
   for jj=1:n % constant bounds loop inside PARFOR
      x(ii,jj) = rand;
   end
end
In the case where your inner for loop has non-constant bounds, then @Greig's solution is the way to go.
Ver también
Categorías
				Más información sobre Loops and Conditional Statements en Help Center y File Exchange.
			
	Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


