How can I identify the indices of rows containing all NaNs from matrix?

16 visualizzazioni (ultimi 30 giorni)
I have very large matrices, in which some rows contain all NaN. I don't want to remove these rows. But I wish to identify which index contains all NaN. I have seen code for removing such rows, but how can I extract the index value?
I am not very familiar with MATLAB. Thanks in advance.

Risposta accettata

Star Strider
Star Strider il 31 Mag 2017
Try this:
M = [rand(3,5); NaN(1,5); rand(4,5); NaN(1,5); rand(2,5)]; % Create Data
NaN_rows = find(all(isnan(M),2)); % Identify ‘NaN’ Rows By Index

Più risposte (1)

Chandrasekhar
Chandrasekhar il 31 Mag 2017
% idenfity NaN's in the matrix
k = isnan(a);
% find the indices of NaN's
find(k==1);
  1 Commento
Deepa T
Deepa T il 1 Giu 2017
Thank you for your reply. This query helps me to identify every NaN in the dataset, not just the rows with all NaN.

Accedi per commentare.

Community Treasure Hunt

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

Start Hunting!

Translated by