How to replace NaN with column mean if less than b NaN in a column?
2 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Katerina F
am 20 Okt. 2014
Kommentiert: Katerina F
am 22 Okt. 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 Kommentare
Akzeptierte Antwort
Andrei Bobrov
am 20 Okt. 2014
Bearbeitet: Andrei Bobrov
am 21 Okt. 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 Kommentare
Weitere Antworten (0)
Siehe auch
Kategorien
Mehr zu NaNs finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!