How to cut a sparse gpuArray
7 views (last 30 days)
Show older comments
I am trying to save memory on my GPU by saving sparse data, but matlab gives this error whenever I try to cut a sparse gpuArray in the following way.
Error using gpuArray/subsref
Sparse gpuArrays are not supported for this function.
Ex.
A=gpuArray(sparse(randi([0,1],2000,2000)));
B=A(1:50,:);
Is there any way to cut sparse gpuArrays, or am I stuck transferring data between my CPU and GPU?
NOTE: This is a piece of example code. Although this piece of code will not have memory benefits from a sparse array, my application will.
0 Comments
Accepted Answer
Matt J
on 31 Aug 2016
Here's a workaround equivalent to B=A(1:50,:), but I do agree it seems unnecessarily awkward.
B = gpuArray.speye(50,2000) * A;
0 Comments
More Answers (1)
Sean de Wolski
on 31 Aug 2016
For the sparsity level of that matrix ~50%, the sparse array is much bigger than a regular array:
x = randi(1,100,100);
xs = sparse(x);
whos x xs
Name Size Bytes Class Attributes
x 100x100 80000 double
xs 100x100 160808 double sparse
You're better off just using a regular array. And you can generate randi directly on gpu so it doesn't need to be transferred:
gpuArray.randi(1,100,100)
See Also
Categories
Find more on Creating and Concatenating Matrices in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!