Why GPU performance is worse than CPU for this code?
3 次查看(过去 30 天)
显示 更早的评论
clear all
close all
tic
t=9999;
X = rand( t, 'single' );
G = gpuArray( X );
isequal( gather( G ), X ) % returns true
classUnderlying( G ) % returns 'single'
G2 = G .* G
toc
tic
X = rand( t, 'single' );
G1 = X;
G3 = G1 .* G1 ;
toc
The execution time of GPU is less than CPu i5. Would anybody answer it?
1 个评论
Jan
2011-11-27
About "clear all" see: http://www.mathworks.com/matlabcentral/answers/16484-good-programming-practice#answer_22301
Please decide, if the "GPU performance is worse than CPU", or if "the execution time of GPU is less than CPU".
采纳的回答
Walter Roberson
2011-11-27
There is a lot of overhead for sending data to a GPU. It is only faster for sufficiently big matrices.
Also, in the first one you are including the "isequal" and the "classUnderlying" in the timing, neither of which is needed for the computation. It is not fair to time different sets of activities.
更多回答(2 个)
Jan
2011-11-27
Please try this:
X = rand(1e3, 1e3, 'single' );
G = gpuArray( X );
G2 = G;
tic
for i = 1:100
G2 = G2 .* G;
end
toc
tic
G = X;
G2 = X;
for i = 1:100
G2 = G2 .* G;
end
toc
cdarling
2012-2-19
there is a possibility that your GPU supports parallel.gpu.GPUArray.rand(), and it would be much faster if you construct random numbers within GPU, instead of generate and copy them into GPU
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 GPU Computing 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!