Searching for a value in a column

Hi,
I have a column with incrementing data which occasionally resets to zero. How do I search the column and check that each value isn't smaller than the previous entry? From that point I can simply add the previous value to all future value to remove the zeroing error, but I can't figure out how to scan down the column.
Cheers

 Réponse acceptée

Walter Roberson
Walter Roberson le 11 Avr 2011

1 vote

find(diff(YourColumn) < 0)
There might be a way to do your entire operation in one or two commands; it doesn't immediately come to mind, though.

3 commentaires

James
James le 11 Avr 2011
Thanks Walter,
It's always a far simpler solution than you imagine!
Teja Muppirala
Teja Muppirala le 12 Avr 2011
Here's one way to do it in one line:
x = [10 14 17 2 5 6 1 2 3]
x(1) + [0 cumsum( max(diff(x),0) + (diff(x) < 0).*x(2:end))]
Walter Roberson
Walter Roberson le 12 Avr 2011
Well done, Teja. I hadn't figured out a way to handle multiple zeroings; your code takes them in stride nicely.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Creating, Deleting, and Querying Graphics Objects dans Centre d'aide et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by