large 3D Matrix calculation

1 vue (au cours des 30 derniers jours)
rahman
rahman le 20 Jan 2015
Commenté : rahman le 25 Jan 2015
Hi All I have two large matrix and I want to calculate an expression without for loop. this expression is something like matrix d as below
f=[f1 f2 f3]
r=[r1 r2 r3]
d=[f1-r1 f2-r1 f3-r1
f1-r2 f2-r2 f3-r2
f1-r3 f2-r2 f3-r3]
can any one help me?! consider that size(f)=1*1*400 and size(r)=50*50*900 and fii=f(1,1,ii) and rjj=r(:,:,jj)

Réponse acceptée

Stephen23
Stephen23 le 20 Jan 2015
Modifié(e) : Stephen23 le 21 Jan 2015
You gave this code in a comment to my other answer:
size(f)==[1,350]
size(r)==[50,50,900]
for ii=1:350
for jj=1:900
s(ii,jj) = sum(sum(sum( repmat(f(ii),[50,50,1]) - r(:,:,jj) ))) ;
end
end
You can try this instead:
A = 50*50*reshape(f,1,[]);
B = reshape(sum(sum(r,1),2),[],1);
C = bsxfun(@minus,A,B);
It produces the same result as your nested loops.
  1 commentaire
rahman
rahman le 25 Jan 2015
tnx Stephen Cobeldick. your code was completely helpfull ;)

Connectez-vous pour commenter.

Plus de réponses (2)

Stephen23
Stephen23 le 20 Jan 2015
Modifié(e) : Stephen23 le 20 Jan 2015
This is exactly what bsxfun is for:
f = [f1,f2,f3];
r = [r1,r2,r3];
d = bsxfun(@minus,f,r.');
bsxfun calculates the output without requiring large intermediate arrays (eg using repmat). Although, depending on the size of d, you might still run out of memory...
  3 commentaires
Stephen23
Stephen23 le 20 Jan 2015
Modifié(e) : Stephen23 le 20 Jan 2015
What you have now described is a different problem to the one that you posed in your original question. My code exactly solves your original question.
John D'Errico
John D'Errico le 20 Jan 2015
The heartache of those who write code - shifting specs. The correct answer to the question asked but not the question intended. :)

Connectez-vous pour commenter.


dpb
dpb le 20 Jan 2015
d=repmat(f,size(r,2),1).-repmat(r.',1,size(f,2));
  1 commentaire
rahman
rahman le 20 Jan 2015
tnx dpb but this operation needs much RAMs according to what I said ( consider that size(f)=1*1*400 and size(r)=50*50*900 and fii=f(1,1,ii) and rjj=r(:,:,jj) )

Connectez-vous pour commenter.

Catégories

En savoir plus sur Loops and Conditional Statements dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by