Hello All,
I am trying to make use of parfor, but I keep getting the following error "parfor cannot run due to the way the variable 'data' is used." Any thoughts?
Thanks in advance
parfor iel=1:tne
start=(iel-1)*576+1;
end1=576*iel;
data(start:end1)=data2(iel,:);
end

 Accepted Answer

parfor iel=1:tne
data((iel-1)*576+1:576*iel)=data2(iel,:);
end
That is, MATLAB can analyze literal indices in ways that it cannot do when those indices are computed.
However, unless you have good reason not to, you should simply create data as a 576 x something array and without using parfor,
data(:, 1:tne) = data2(:, 1:tne) .';
... especially if you can manage to compact it down to just
data = data2 .';
After the copying has been done with 2D indices, then it is very fast to
data = reshape(data, 1, []);

5 Comments

Many thanks Walter for the answers!
I could not follow what you have mentioned. May you elaborate more?
Thanks
What is size(data) before the parfor loop? What is size(data2) ? What is tne ?
Before the parfor loop data is initialized as
data=zeros(tne*576,1);
tne is the total number of elements in the finite element analysis. What I am trying to do is construct the global stiffness matrix as a sparse matrix.
parfor iel=1:tne
data((iel-1)*576+1:576*iel)=data2(iel,:);
end
K=sparse(row,col,data,ndof,ndof)
size of data2 is tnex576
Then
data = reshape(data2.', 1, []);
with no loop.
Oops! You are right!
Thanks a lot

Sign in to comment.

More Answers (0)

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!