Is it possible to vectorize this ?

2 visualizzazioni (ultimi 30 giorni)
Omar Ali Muhammed
Omar Ali Muhammed il 26 Apr 2021
Modificato: Matt J il 26 Apr 2021
A matrix A(100x1000) a selective column defined in B(1x1000). The required processing is the mean of non zero elements of each column of A referenced by B. Without the use of loops.
Regards

Risposta accettata

Matt J
Matt J il 26 Apr 2021
Modificato: Matt J il 26 Apr 2021
A(~A)=nan;
result=mean(A(:,B),1,'omitnan')
  2 Commenti
Omar Ali Muhammed
Omar Ali Muhammed il 26 Apr 2021
Dear, it is wonderful.
How can we 'omitnan' if we replace mean by trimmean?
Matt J
Matt J il 26 Apr 2021
Modificato: Matt J il 26 Apr 2021
Dear, it is wonderful.
I'm very glad. Please Accept-click the answer to indicate so.
How can we 'omitnan' if we replace mean by trimmean?
What would you be excluding?Zeros again? If so,
A(~A)=inf;

Accedi per commentare.

Più risposte (1)

Jan
Jan il 26 Apr 2021
AB = A(:, B);
result = sum(AB, 1) ./ sum(AB ~= 0, 1);
mean('omitnan') replaces the NaNs by zeros for the summation and calculates the number of non-NaNs by sum(~isnan(AB)). Therefore this code should be faster, because it avoids replacing zeros by NaNs and back to zeros again.
  1 Commento
Matt J
Matt J il 26 Apr 2021
Modificato: Matt J il 26 Apr 2021
because it avoids replacing zeros by NaNs and back to zeros again.
+1. Although, I would argue, they probably should have been NaNs instead of zeros from the very beginning.

Accedi per commentare.

Prodotti


Release

R2021a

Community Treasure Hunt

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

Start Hunting!

Translated by