Help speeding up matrix algebra in loop...

1 view (last 30 days)
Hi everyone, I'm simply looking for some suggestions for speeding up the following block of code:
bhat = (X'*X)\(X'*y);
yhat = X*bhat;
resid = y - yhat;
bclu=zeros(size(X,2));
for i=idx.unique
idmat=find(idx.sample==i);
x_g=X(idmat,:);
u_g=resid(idmat,:);
bclu_i=x_g'*u_g*(u_g)'*x_g;
bclu = bclu+bclu_i;
end
vhat=((X'*X)\bclu)/(X'*X);
I suppose there might be some scope for the use of "sparse" here, or perhaps vectorization, but it's not obvious to me how to optimize this. Any suggestions would be great. Thanks!

Accepted Answer

Walter Roberson
Walter Roberson on 28 Aug 2015
You could probably use parfor, if you have the Parallel Computing Toolkit.
  2 Comments
John
John on 28 Aug 2015
Oops! Didn't mean to accept so quickly!
This code is part of an optimization routine which itself is run in parallel, so I can't easily use parallel here. Any other suggestions?

Sign in to comment.

More Answers (0)

Categories

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

Community Treasure Hunt

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

Start Hunting!