Can I vectorise or make this 'find' double-loop run faster?

조회 수: 1 (최근 30일)
J Yadav
J Yadav 2018년 4월 2일
댓글: Stephen23 2018년 4월 3일
Hi, Is there a possible way in which the formula that uses 'find' to update a matrix could do away with the double loops and make this calculation faster. Inputs:
1) Cmat - a 13x13 matrix,
2) Hist - a 1000x21 matrix of random numbers,
3) Chain - a 1000x22 matrix, such that Chain(:,1) contains numbers 1:13 and Chain(:,2:22) are zeros.
I run two loops to update the Chain matrix as follows:.
for i=2:size(Chain,2);
for k=1:size(Hist,1)
Chain(k,i) = find(Hist(k,i)< Cmat(Chain(k,i-1),:),1);
end
end
any suggestions are welcome.
Thanks for your inputs.
jayant

채택된 답변

Matt J
Matt J 2018년 4월 2일
편집: Matt J 2018년 4월 2일
Assuming R2016b or later,
for i=2:size(Chain,2)
[~,Chain(:,i)] = max( Hist(:,i) < Cmat(Chain(:,i-1),:) ,[],2);
end
  댓글 수: 2
J Yadav
J Yadav 2018년 4월 3일
That's a marvellous reply. I don't understand the ~ notation, but the solution works and reduced my calculation time by > 90%. Thank you very much.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile 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