Deleting All the Rows with values Bigger or equal than 10

22 visualizaciones (últimos 30 días)
Hello,
I have an array Output (2106x).
I would like to delete all rows from it it the value in the fourth column is greater or equal than 10.
My idea was to create a for loop that checked all the values in the fourth column and if the value was bigger than 0 than the entire corresponding row is deleted.
Is this approach the fastest or should I do in another way?
I tried this but this is not working, where I'm wrong?
I think the problem is that is doing the look on the length of the original Output array, but since then is deleting the elements, the array length is smaller, and the program cannot deal with it
for i=1:length(Output(1,4))
if Output(i,4) >= 10
Output(i,:) = [],
end
end

Respuesta aceptada

Walter Roberson
Walter Roberson el 6 de Jul. de 2022
mask = Output(:,4) >= 10;
Output(mask,:) = [];

Más respuestas (0)

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by