Replace for loop with matrix function, for function acting on matrix columns
Show older comments
Let L be an n x n matrix, and let M be an n x p matrix. (In practice p << n/2, but n is of order 10^{5} or greater). I'd like to construct the n x p matrix N, with entries $N_{ij} = sum_k L_{ki}/M_{kj}$.
At present I'm using the for loop below. How can it be accelerated/avoided?
% Generate random matrices %
n = 100; p = 35;
L = rand(n,n);
M = rand(n,p);
%
% Produce N from L and M, where N_{ij} = sum_k Lki/Mkj %
N = inf(n,p);
for i = 1:n
Li = L(:,i);
for j = 1:p
Mj = M(:,j);
N(i,j) = sum(Li./Mj);
end
end
Accepted Answer
More Answers (2)
Bruno Luong
on 24 Oct 2018
N = L.' * (1./M)
5 Comments
Stephen23
on 24 Oct 2018
+1 best use of MATLAB
greengunpowder
on 24 Oct 2018
Bruno Luong
on 24 Oct 2018
Edited: Bruno Luong
on 24 Oct 2018
But do you know which method is more accurate?
greengunpowder
on 24 Oct 2018
Bruno Luong
on 24 Oct 2018
The order of the summation is different when one uses SUM, or MTIMES and it also depends on the number of threads (so the CPU that MATLAB is running), which in return gives different summation results. So far the discrepancy is observed, but AFAIK no-one is able to question matrix MTIMES in a causual use cases.
madhan ravi
on 24 Oct 2018
Edited: madhan ravi
on 24 Oct 2018
n = 100;
p = 35;
M = rand(n,p)
L = rand(n,n)
N = sum(L./M)
2 Comments
madhan ravi
on 24 Oct 2018
You don't need loop to do this operation
greengunpowder
on 24 Oct 2018
Categories
Find more on Numerical Integration and Differentiation 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!