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

 채택된 답변

Walter Roberson
Walter Roberson 2019년 2월 1일

1 개 추천

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

Diab Abueidda
Diab Abueidda 2019년 2월 1일
Many thanks Walter for the answers!
I could not follow what you have mentioned. May you elaborate more?
Thanks
Walter Roberson
Walter Roberson 2019년 2월 1일
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.
Diab Abueidda
Diab Abueidda 2019년 2월 1일
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