In parfor , why a variable cannot be classified?

1 view (last 30 days)
In the code below I get an error
Error: The variable Matrix in a parfor cannot be classified.See Parallel for Loops in MATLAB, "Overview".
parfor i=1:n
try
query = 'SELECT * FROM TABLE WHERE Criterion = '' criteria(i) ''';
curs = exec(conn, query);
curs = fetch(curs);
close(curs);
results = curs.Data;
A = f(results);
B = g(results);
C = h(results);
D = k(results);
Matrix(i,6:9) = horzcat(A,B,C,B);
catch
Matrix(i,6:9) = {0,0,0,0};
end
end
Any ideas what I am missing?
  2 Comments
Walter Roberson
Walter Roberson on 2 Jul 2015
Do A, B, C, D come out as cell arrays? At the moment it looks plausible that you have storing a numeric vector in one case and a vector of cells in the other case.
sm
sm on 2 Jul 2015
Yes, A,B,C and D are all cells. Also, note that the parfor loop runs fine as a simple for loop.

Sign in to comment.

Accepted Answer

Walter Roberson
Walter Roberson on 3 Jul 2015
write to
tMatrix(i,:) = horzcat(A,B,C,B);
or write {0,0,0,0} there. Then after the parfor, let
Matrix(:,6:9) = tMatrix;
The difficulty you are running into is that you are trying to update only part of one row of a matrix, which requires that the matrix be input to the parfor as well as output from the parfor. parfor can handle rows that are only input and rows that are only output, but it doesn't like input-update-output as your code is requiring. The adjusted version I show has the entire row of tMatrix be output, and that is fine with parfor.

More Answers (1)

Brendan Hamm
Brendan Hamm on 2 Jul 2015
Preallocate your matrix before the loop:
Matrix = nan(n,9)
Although lookingat your catch statement is Matrix a cell array? That is confusing.
  1 Comment
sm
sm on 2 Jul 2015
I do pre-allocate the cell array before the parfor loop
n = size(data,1);
Matrix = cell(n,14);
Matrix(:,1:5) = data;
parfor i=1:n
....
end

Sign in to comment.

Categories

Find more on Parallel for-Loops (parfor) in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!