Vectorize product cell vectors
조회 수: 2 (최근 30일)
이전 댓글 표시
I need to efficiently compute the quantity
where
and
,
, are
vectors and
are
sparse matrices.
data:image/s3,"s3://crabby-images/51625/5162577bc415352371d8d56dede96f4ac5654c38" alt=""
data:image/s3,"s3://crabby-images/7eb17/7eb1746bfc6a0afaefd3525cbf4abc2b7edc2a8b" alt=""
data:image/s3,"s3://crabby-images/f82df/f82dffb6f65f6e0a9d624e93b7ec1c57525f4d6c" alt=""
data:image/s3,"s3://crabby-images/391b7/391b7c801443c53a70c9a2eae34ebd88f33e06ae" alt=""
data:image/s3,"s3://crabby-images/b3b91/b3b91dbe374777d911db674cdc1eacba96965f56" alt=""
data:image/s3,"s3://crabby-images/728e6/728e6f52a84619a89d2d05a540d16da800029006" alt=""
data:image/s3,"s3://crabby-images/6b562/6b562c0268c33415e69ae9f0ea94a3b4e16d06da" alt=""
If the matrices
were not sparse, then I could use a 3D array and probably vectorize some of the operations.
data:image/s3,"s3://crabby-images/503ff/503ff6c6c1e4b45754baee4449c3716ecedf15f4" alt=""
Right now, I am using a cell structure to store the matrices and I store the vectors in
matrices.
data:image/s3,"s3://crabby-images/acf2d/acf2db3854c1c7b19728baabf4dd746420f8bb56" alt=""
Here's the relevant part of the code that I am using:
res = 1;
for k = 1:N
res = res * (u(:, k).' * A{k} * v(:, k));
end
For reference, in my case
and
0, and the loop takes about 2 seconds. In my code, this loop is called several times, so it would make a great impact to reduce its runtime.
data:image/s3,"s3://crabby-images/f6ba8/f6ba83aef20e2fb82ae76d3d4c6c814f27334d91" alt=""
data:image/s3,"s3://crabby-images/42e72/42e72397766aeb231f499b67ae08ddd9a25cf239" alt=""
How can I improve the performance of the loop? Can it be vectorized? Should I be computing it in another way?
Thank you.
댓글 수: 0
채택된 답변
Srivardhan Gadila
2021년 11월 17일
I think that, you are already representing the matrices of the cell array A in the sparse form and in that case you are already having the best performance. You can refer to the documentation page of Sparse Matrices and the following MATLAB Answer: Is there a faster way to multiply a sparse and full matrix than standard multiplication in Matlab? for any additional information.
Although, I have tried experimenting the code by making use of gpuArray, and it seems that for m = 100,000 and n = 100 it was consuming less time of all, on my machine. At the same time for lower values of m it is slower. Once try executing the below code:
clc; clear all
%%
m = 100000; N = 100;
u = randn(m,N); v = randn(m,N);
ug = gpuArray(u); vg= gpuArray(v);
A = {}; As = {}; Asg = {};
for i = 1:N
As{i} = sprand(m,m,1/m);
A{i} = full(As{i});
Asg{i} = gpuArray(As{i});
end
%% Not using sparse representation
tic
res = 1;
for k = 1:N
res = res * (u(:, k).' * A{k} * v(:, k));
end
toc
%% Using sparse representation
tic
res = 1;
for k = 1:N
res = res * (u(:, k).' * As{k} * v(:, k));
end
toc
%% Using arrayfun
tic
res = arrayfun(@(k)fun(As,u,v,k),1:N);
res = prod(res);
toc
%% Using gpuArray
tic
res = 1;
for k = 1:N
res = res * (ug(:, k).' * Asg{k} * vg(:, k));
end
toc
function out = fun(A,u,v,k)
out = (u(:, k).' * A{k} * v(:, k));
end
댓글 수: 0
추가 답변 (0개)
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!