How to replace NaN with column mean if less than b NaN in a column?
2 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
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
0 commentaires
Réponse acceptée
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
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur NaNs 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!