Effacer les filtres
Effacer les filtres

How to replace NaN with column mean if less than b NaN in a column?

1 vue (au cours des 30 derniers jours)
Katerina F
Katerina F le 20 Oct 2014
Commenté : Katerina F le 22 Oct 2014
Hello, Say I have the martix:
MA=[1 2 3 NaN; 6 NaN NaN 9; NaN NaN NaN 9;NaN 45 NaN 9;NaN NaN NaN 19;1 12 3 34] I would like to replace the NaNs in each column with the average of the column if the number of NaNs in the column is less than 4. Any easy way to do this please? I know that to find the average of the column I can use the nanmean function. Note that the actual matrices that I have are much larger, but I know the total number of rows and columns.
thanks, K

Réponse acceptée

Andrei Bobrov
Andrei Bobrov le 20 Oct 2014
Modifié(e) : Andrei Bobrov le 21 Oct 2014
n = nanmean(MA);
nn = isnan(MA);
ii = sum(nn) < 4;
z = MA(:,ii);
z(nn(:,ii)) = nonzeros(bsxfun(@times,nn(:,ii),n(ii)));
MA(:,ii) = z;
or
n = nanmean(MA);
nn = isnan(MA);
ii = bsxfun(@and,nn,sum(nn) < 4);
MA(ii) = n(nonzeros(bsxfun(@times,ii,1:numel(n))));
or
n = nanmean(MA);
nn = isnan(MA);
ii = bsxfun(@and,nn,sum(nn) < 4);
[~,idx] = find(ii);
MA(ii) = n(idx);
  3 commentaires
Andrei Bobrov
Andrei Bobrov le 21 Oct 2014
corrected
Katerina F
Katerina F le 22 Oct 2014
Thank you very much Andrei, it works fine. K.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by