I would like to upload two images to the GPU memory, and I’m interested how fast I can do this?
In fact – will it be faster to compare two bitmaps in RAM with CPU, or upload them to GPU and use GPU parallelism to do it?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
If you run the CUDA device bandwidth sample, you’ll get a benchmark for the upload speed.
Assuming DDR3 tri-channel 1600MHz RAM, you’ll get something like 38 GB/s memory bandwidth.
Take a typical midrange card like a GTX460 and you’ll get something like 84 GB/s memory bandwidth. Note that you’ll have to make a hop across the bus which is something like 8GB/s theoretical, ~5.5 in practice for a PCI-E2.0 x16 link.
Note that kotlinski’s answer isn’t quite correct. You’ll can do compared in parallel and then do a parallel reduction in which case, the bigger GPU device bandwidth can work win out eventually.
I think the answer is likely to be: a loss to upload to GPU and do comparison once. Possible gain if comparison is made multiple times (kept and modified on the GPU, for example).
Edit:
The multiple times comparison refers to if you modified the images on the GPU memory in situ. Thus, it would merit another comparison (caching doesn’t cut it), while not incurring the penalty of another copy across the bus.