Find negative in every n rows

I have a 2184 x 14 matrix. In column 1 is the datenum value and in column 14 the values that I want to consider. The other columns contain some other data.
I want to consider the first 24rows if any of the values in column 14 are negative. I want to delete the first 24rows and then repeat this for the following 24rows.

 Risposta accettata

Andrei Bobrov
Andrei Bobrov il 12 Mag 2017
Modificato: Andrei Bobrov il 15 Mag 2017
One way
% A - your data [2184 x 14]
ii = ceil((1:size(A,1))'/24);
jj = accumarray(ii,A(:,14),[],@(x)all(x >= 0)); % EDIT
out = A(jj(ii),:);

2 Commenti

David du Preez
David du Preez il 15 Mag 2017
Modificato: David du Preez il 15 Mag 2017
That does not work. It does not find any negative neither removes them. attached in the matrix in question
I'm fixed my answer.

Accedi per commentare.

Più risposte (1)

Jan
Jan il 15 Mag 2017
Modificato: Jan il 15 Mag 2017
Data = rand(2184, 14) - 0.1; % Test data
D = reshape(Data, 24, [], 14);
Match = any(D(:, :, 14) < 0, 1);
Result = reshape(D(:, Match, :)), [], 14);

Categorie

Community Treasure Hunt

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

Start Hunting!

Translated by