vectorization of nested for loop

i want to transfer an image pixels coordination into matrix (rows x 2) , this is the code with for loops, i want to vectorize it because it takes so much time for big images.
I=imread('1.bmp');
[rows,columns,~]=size(I);
pix_im=[];
for l=1:rows
for c=1:columns
pix_im=[pix_im;l c];
end
end

 Risposta accettata

Ameer Hamza
Ameer Hamza il 15 Nov 2020
Modificato: Ameer Hamza il 15 Nov 2020
No wonder this code runs slow. You are using dynamic memory allocation. You can get several-fold speed gain just by pre-allocation: https://www.mathworks.com/help/matlab/matlab_prog/preallocating-arrays.html. However, you don't even need a loop for this. You can do it much more efficiently like this.
I=imread('1.bmp');
[rows,columns,~]=size(I);
[c,r] = ndgrid(1:columns, 1:rows);
pix_im = [r(:) c(:)]

3 Commenti

chabani mohammed ali
chabani mohammed ali il 15 Nov 2020
Modificato: chabani mohammed ali il 15 Nov 2020
thank you so much it works and it's fast just like i want.
i was trying to do the same thing with meshgrid but i couldn't get a correct result ( am new to matlabe),
and even when i use a loop with pre-allocation the way you proposed is faster. thank you again.
I am glad to be of help!

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Loops and Conditional Statements in Centro assistenza e File Exchange

Prodotti

Release

R2019a

Community Treasure Hunt

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

Start Hunting!

Translated by