Code optimization with GPU

Hi everyone, I have the following line of codes which I would like to parallelize on the GPU :
U = zeros(q, M, q, 'gpuArray');
for j=1:q
U(j,:,j) = my_line_vector;
end
Is there any way to suppress the loop?
Thes are the lines of code that run the slowest in my program.
Thank you in advance
Michel

 Risposta accettata

Joss Knight
Joss Knight il 16 Gen 2021
Modificato: Joss Knight il 16 Gen 2021
I = reshape(gpuArray.eye(q),q,1,q);
U = I.*my_line_vector;

4 Commenti

POHL Michel
POHL Michel il 16 Gen 2021
Hi, no it does not work, in your case U does not have any zeros,
whereas in my case U has a lot of zeros.
Joss Knight
Joss Knight il 16 Gen 2021
Ah yes, sorry about that. I've edited the original, see if that works.
POHL Michel
POHL Michel il 16 Gen 2021
Thank you, it works!
I did not know that the element wise product worked with matrices with different size.

Accedi per commentare.

Più risposte (0)

Tag

Community Treasure Hunt

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

Start Hunting!

Translated by