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

 采纳的回答

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 个评论

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

请先登录,再进行评论。

更多回答(0 个)

类别

帮助中心File Exchange 中查找有关 Loops and Conditional Statements 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by