Dealing with NaNs in a code

9 visualizaciones (últimos 30 días)
Nicu Sprincean
Nicu Sprincean el 7 de Abr. de 2017
Comentada: Star Strider el 10 de Abr. de 2017
Hi everyone, I'm struggling with a code that doesn't accept the NaNs. This is a part of a bigger code:
data = [y1 y2];
for i=1:5
c(:,i) = mean(data(:,i));
d(:,i)=(data(:,i));
data_demeaned(:,i) = d(:,i) - c(:,i);
end
I've tried to do this:
c(:,i) = nanmean(data(:,i));
d(:,i)= data(:,i)(~isnan(data(:,i)));/ d(:,i)=~isnan(data(:,i));
data_demeaned(:,i) = d(:,i) - c(:,i);
but it doesn't work. Any suggestion would be highly appreciated.

Respuestas (1)

Star Strider
Star Strider el 7 de Abr. de 2017
I believe you’re making this more difficult than it needs to be. I do not understand what you are doing with your ‘d’ matrix, since the code doesn’t make sense, so please explain it.
Try this:
data = rand(1,30); % Create Data
data(randperm(30,10)) = NaN; % Create Data (Insert ‘NaN’ Values)
data = reshape(data, [], 5); % Create Data
c = nanmean(data);
data_demeaned = data - c;
  12 comentarios
Nicu Sprincean
Nicu Sprincean el 10 de Abr. de 2017
Editada: Nicu Sprincean el 10 de Abr. de 2017
Hi, again. I have another issue. I have a MxN matrix (matrix A) and I run the following code:
B = A(~isnan(A));
but I get a Mx1 vector as a result. How could I manage it to get a matrix, with the same number of columns (N)? Or this happens due to the fact that the number of rows is not equal? Thank you.
Star Strider
Star Strider el 10 de Abr. de 2017
My pleasure.
That is normal, and results from numeric arrays not being defined to have ‘empty’ elements, so the matrix structure disappears and produces a vector of the ‘non-NaN’ values. (Cell arrays can have empty elements.)
You can create the original matrix as a cell array with the num2cell function. That will allow ‘empty’ elements, although it introduces the complexities of calculating with cell arrays, and does not eliminate your original problem.
That it has (Mx1) elements indicates to me that it has (M-1)*N elements that were NaN.
Since you have functions available that automatically calculate with NaN values and handle them as you want them to, I would just use those functions and not deal with eliminating the NaN values or using cell arrays.

Iniciar sesión para comentar.

Categorías

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

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by