필터 지우기
필터 지우기

Sparse for element by element operation

조회 수: 7 (최근 30일)
D_coder
D_coder 2018년 9월 15일
댓글: D_coder 2018년 9월 16일
If we want to perform the product of two sparse matrices or sparse and a full matrix , sparse function is very useful as it avoids multiplications with zero. However when we do element by element multiplication of two sparse matrices or a sparse matrix and a full matrix it is observed that it takes a considerable amount of time as compared to the multiplication of full matrices. Here is a concrete example
A = sprand(1000,1000,0.005);
B = rand(1000,1000);
Af = full(A);
timeit(@() Af.*B)
ans =
5.1227e-04
timeit(@() A.*B)
ans =
0.0011
How do I tackle this issue when I am looking for a considerable lower time than the multiplication of two full matrices?

답변 (2개)

Bruno Luong
Bruno Luong 2018년 9월 15일
편집: Bruno Luong 2018년 9월 15일
A = sprand(1000,1000,0.005);
B = rand(1000,1000);
tic
Af = full(A);
AB=Af.*B;
toc % Elapsed time is 0.011628 seconds.
tic
AB=A.*B;
toc % Elapsed time is 0.004143 seconds.
Recommended solution
tic
[i,j,a]=find(A);
b=B(sub2ind(size(B),i,j));
AB=sparse(i,j,a.*b);
toc % Elapsed time is 0.001570 seconds.
  댓글 수: 3
Bruno Luong
Bruno Luong 2018년 9월 16일
편집: Bruno Luong 2018년 9월 16일
Why you think my code assumes some loop or not ? It just carries out the element-wise product A.*B like other methods.
D_coder
D_coder 2018년 9월 16일
It's not your code that assumes a loop , my code has a loop that runs for 9000 times and I have already tried doing sparse inside it , it gives me a worse performance than the original thing without sparse

댓글을 달려면 로그인하십시오.


Bruno Luong
Bruno Luong 2018년 9월 15일
편집: Bruno Luong 2018년 9월 15일
You might also interested in this FEX
[i,j]=find(A);
b=B(sub2ind(size(B),i,j));
AB=setsparse(A,i,j,b,@times);

카테고리

Help CenterFile Exchange에서 Sparse Matrices에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by