Converting this 3-nested for loop for parfor
3 ビュー (過去 30 日間)
古いコメントを表示
The context is a finite element assembly routine where I need to loop over a bunch of mesh elements. In principle, each iteration computes a small local matrix (3x3 in this case) and inserts it into the much larger global matrix according to the indices ie and je.
The iterations are completely independent of each other as I'm pretty sure as my code stands now, it could run through the outer loop in any order without any problems. But of course, this version isn't accepted by MATLAB for parfor format. Can anyone help me out here?
NLoc = 3;
Klocal = zeros(NLoc);
blocal = zeros(NLoc,1);
Aglobal = zeros(NLoc*nElem);
bglobal = zeros(NLoc*nElem,1);
for k=1:nElem
kk = NLoc*(k-1);
Klocal = function1(nElem,k);
blocal = function2(nElem,k);
for i=1:NLoc
ie = i+kk;
bglobal(ie) = bglobal(ie) + blocal(i);
for j=1:NLoc
je = j+kk;
Aglobal(ie,je) = Aglobal(ie,je) + Klocal(i,j);
end
end
end
0 件のコメント
採用された回答
Matt J
2013 年 11 月 9 日
編集済み: Matt J
2013 年 11 月 9 日
If I'm interpreting it right, it looks like
Aglobal = cell(nElem,1);
bglobal = cell(nElem,1);
parfor k=1:nElem
Aglobal{k}=function1(nElem,k);
bglobal{k}=function2(nElem,k);
end
Aglobal=blkdiag(Aglobal{:});
bglobal=cell2mat(bglobal);
3 件のコメント
Matt J
2013 年 11 月 9 日
You can create an MxN cell array to hold the blocks and fill them as you wish. Essentially, the same was done above with bglobal, which was not block diagonal.
その他の回答 (0 件)
参考
カテゴリ
Help Center および 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!