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

1 visualización (últimos 30 días)
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

Respuesta aceptada

Andrei Bobrov
Andrei Bobrov el 20 de Oct. de 2014
Editada: Andrei Bobrov el 21 de Oct. de 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 comentarios
Katerina F
Katerina F el 22 de Oct. de 2014
Thank you very much Andrei, it works fine. K.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre NaNs en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by