sum of product of 2 matrices

hi
i have 2 matrices... u is a 2 x 1250 matrix and r is a 1250 x 1250 matrix...
here c = 1
for each j = 1 to 1250 i want to find
how to writ the matlab code for this ?

Antworten (2)

Zoltán Csáti
Zoltán Csáti am 10 Jan. 2015

2 Stimmen

It is just a standard matrix-matrix product: u*r. So enter
value = u(1,:)*r;
The j-th column of the matrix "value" will contain the sum for the specific j.

4 Kommentare

Sreejith
Sreejith am 10 Jan. 2015
This is only the product..
i want to find the sum of the products
u(c,1)*r(1,j) + u(c,2)*r(2,j) +.....+u(c,i)*r(i,j) where i = 1,2,3...,1250
what will be the code ?
Matt J
Matt J am 10 Jan. 2015
But u(1,:)*r is a matrix product. It is equivalent to the summation you've shown.
Zoltán Csáti
Zoltán Csáti am 10 Jan. 2015
This is what my code does. Write a few indices and you will see.
John D'Errico
John D'Errico am 10 Jan. 2015
Bearbeitet: John D'Errico am 10 Jan. 2015
+1. What you don't seem to understand is that the * operator IS a dot product, i.e., the sum of products of elements. After all, MATLAB is a matrix language, so it is written to do these computations trivially, with the basic operators.
You sum of products is simply a dot product, what * delivers.

Melden Sie sich an, um zu kommentieren.

Guillaume
Guillaume am 10 Jan. 2015

1 Stimme

Use bsxfun:
sum(bsxfun(@times, u(c, :)', r))

3 Kommentare

Sreejith
Sreejith am 10 Jan. 2015
In your answer, there is no mentioning of 'j'...
sum(bsxfun(@times, u(c,:)', r(:,j))
Is this correct ?
Zoltán Csáti
Zoltán Csáti am 10 Jan. 2015
Guillaume provided a vectorized version, that's why there is no matrix index j.
Guillaume
Guillaume am 10 Jan. 2015
bsxfun replicates u(c,:)' for each column j of r and sum calculates the sum for each of these columns. Exactly what you asked for.
Just try my code without any modification.
Note, this is equivalent to:
tempu = repmat(u(c, :)', 1, size(r, 2));
p = tempu .* r;
result = sum(p)
Or, if you really want to introduce j and make the calculation much slower:
tempu = repmat(u(c, :)', 1, size(r, 2));
p = tempu .* r;
result = zeros(1, size(r, 2));
for j = 1:size(r, 2)
result(j) = sum(p(:, j));
end
The one line bsxfun does the same.

Melden Sie sich an, um zu kommentieren.

Kategorien

Gefragt:

am 10 Jan. 2015

Bearbeitet:

am 10 Jan. 2015

Community Treasure Hunt

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

Start Hunting!

Translated by