Effacer les filtres
Effacer les filtres

How to fast process a calculation within a matrix without using a loop?

4 vues (au cours des 30 derniers jours)
Leon
Leon le 29 Mar 2019
Modifié(e) : Leon le 29 Mar 2019
I have a huge matrix A, and what i need to do is to go through each of the matrix element and do this below simple calculation:
[m n] = size(A);
for i=1:m
for j=1:n
B(i,j) = 10^-A(i,j);
end
end
The thing is that it is slow. Is there a way I can avoid the loop and make it faster?
Thank you!
  4 commentaires
Rik
Rik le 29 Mar 2019
Modifié(e) : Rik le 29 Mar 2019
Whenever the size of an array increases, Matlab has to create a copy in memory. This takes a lot of time if you repeat that very often. Your original code would cause the output to be extended m+n-1 times.
Pre-allocation would solve this issue by creating an array in advance of the correct size. If array processing is not possible, it is generally worth it to pre-allocate the output array.
Leon
Leon le 29 Mar 2019
Got you!
Many thanks!

Connectez-vous pour commenter.

Réponse acceptée

Rik
Rik le 29 Mar 2019
Yes, use the power of array processing in Matlab:
B=10.^-A;
  2 commentaires
Leon
Leon le 29 Mar 2019
Many thanks!
Will that be a problem, if my data also contains NaNs?
Rik
Rik le 29 Mar 2019
It will do the same as your loop for NaN values, so the B matrix will contain NaN everywhere where A has a NaN.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Creating and Concatenating Matrices dans Help Center et File Exchange

Tags

Produits


Version

R2019a

Community Treasure Hunt

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

Start Hunting!

Translated by