Help speeding up matrix algebra in loop...

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!

 Respuesta aceptada

Walter Roberson
Walter Roberson el 28 de Ag. de 2015

0 votos

You could probably use parfor, if you have the Parallel Computing Toolkit.

2 comentarios

John
John el 28 de Ag. de 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?
John
John el 28 de Ag. de 2015
Did I miss my chance??

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices en Centro de ayuda y File Exchange.

Preguntada:

el 28 de Ag. de 2015

Comentada:

el 28 de Ag. de 2015

Community Treasure Hunt

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

Start Hunting!

Translated by