Matrix multiply slices of 3d Matricies

15 ビュー (過去 30 日間)
Dan Ryan
Dan Ryan 2013 年 2 月 5 日
Given two 3d matricies, A and B with
size(A) = (n, m, k)
and
size(B) = (m, p, k)
perform matrix multiplications on each slice obtained by fixing the last index, yielding a matrix C with
size(C) = (n, p, k).
To clarify, we would have
C(:, :, 1) = A(:, :, 1)*B(:, :, 1), ..., C(:, :, k) = A(:, :, k)*B(:, :, k).
I need to do this with gpuArrays in the most efficient manner possible.

採用された回答

Jill Reese
Jill Reese 2013 年 9 月 9 日
If you have MATLAB R2013b, you can use the new gpuArray pagefun function like so:
C = pagefun(@mtimes, A, B);
  1 件のコメント
Dan Ryan
Dan Ryan 2013 年 9 月 9 日
Brilliant! Thanks!

サインインしてコメントする。

その他の回答 (2 件)

James Tursa
James Tursa 2013 年 2 月 14 日
編集済み: James Tursa 2013 年 2 月 14 日
If you are not restricted to gpuArrays you can do this:
C = mtimesx(A,B);
The MTIMESX function passes pointers to the slice data to BLAS library functions in the background, so it is pretty fast. You can find MTIMESX here:
MTIMESX is not yet multi-threaded across the third dimension (but an update is in the works). A nD matrix multiply multi-threaded on the third dimension called MMX can also be used:
C = MMX('mult', A, B);
MMX can be found here:
  1 件のコメント
Dan Ryan
Dan Ryan 2013 年 2 月 14 日
great suggestion, I will keep an eye on this project

サインインしてコメントする。


Azzi Abdelmalek
Azzi Abdelmalek 2013 年 2 月 5 日
編集済み: Azzi Abdelmalek 2013 年 2 月 5 日
n=3;
m=4;
k=5;
p=2;
A=rand(n,m,k)
B=rand(m,p,k)
C=zeros(n,p,k)
for ii=1:k
C(:,:,ii)=A(:,:,ii)*B(:,:,ii)
end
  7 件のコメント
Azzi Abdelmalek
Azzi Abdelmalek 2013 年 2 月 5 日
編集済み: Azzi Abdelmalek 2013 年 2 月 5 日
bsxfun don't work with
n=3;
m=4;
k=5;
p=2;
A=rand(n,m,k)
B=rand(m,p,k)
C = bsxfun(@times, A, B);
Jill Reese
Jill Reese 2013 年 2 月 14 日
Dan,
Can you elaborate on the sizes of m, n , k, and p that you are interested in? It would be useful to know a ballpark number for the size of problem you want to solve. Do you have many small page sizes, a few large pages, or something else?
Thanks,
Jill

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeMatrix Indexing についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by