Run custom function on GPU with Parallel Computing Toolbox?

3 views (last 30 days)
I have a function which needs to find min( b -A*x ). The dimensions of b = 5 X 1; A = 5 X 2; x = 2 X 10; The output of A*x would be 5 X 10. and since b is a column vector, the final output will be 5 X 10, [b - A*x] and if we apply min operator we would get 5 X 1. When I try to use the arrayfun function it gives error :- Error using parallel.gpu.GPUArray/arrayfun Matrix dimensions must agree for 'mtimes'

Accepted Answer

Jill Reese
Jill Reese on 18 May 2012
Arrayfun on the GPU only supports elementwise operations, so it is not the command that you want to use in this case.
You need to use min and * (mtimes) directly, which are overloaded to run on the GPU. If at least one of A, b, or x are stored on the GPU (i.e. of type parallel.gpu.GPUArray), then your code snippet will run on the GPU.
  2 Comments
Subhrajit Debnath
Subhrajit Debnath on 19 May 2012
Thanks a lot. I am trying to do bsxfun(@minus,b,A*x);
It is giving error as: Undefined function 'bsxfun' for input arguments of type 'parallel.gpu.GPUArray'.
It seems this function is not supported. I am using Parallel Computing Toolbox Version 5.2 (R2011b).
But this function is listed in the built in functions that support gpuArray.
http://www.mathworks.in/help/toolbox/distcomp/bsic4fr-1.html#bsloua3-1
Jill Reese
Jill Reese on 24 May 2012
The link you provide is for R2012a. If you upgrade your version of MATLAB to R2012a then you will have access to bsxfun on the gpu.

Sign in to comment.

More Answers (1)

Walter Roberson
Walter Roberson on 18 May 2012
column vector minus a matrix is not defined.
You will need to show your arrayfun code; it sounds as if you are using the wrong arguments or wrong function.

Community Treasure Hunt

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

Start Hunting!