У меня есть вектор единиц и нулей, которые представляют, когда возникает прерывистый сигнал данных. Например.:
V = [0,0,0,0,1,1,1,1,1,0,0,0,0,0,1,1,1,0,0,0,1,1,1,1,1,1,1,0,0,0];
Как мне найти значение индекса для каждого изменения от 1 до 0? Итак, для вектора V, приведенного выше, ответ будет следующим:
idx = [10,18,28];





Быстро и просто:
idx=find(diff(V)<0)+1;
Вычислите производную, получите только отрицательные значения (от 1 до 0 равно -1) и найдите местоположения. Поскольку производные начинаются со второго места, нам нужно добавить 1
Однако обратите внимание, что если вы хотите получить доступ к данным в этих местах, лучше использовать логические индексы напрямую, например:
somevals=my_other_data([false;diff(V)<0]);
Подробнее об общей индексации переменных здесь
Вы также можете использовать свертку:
idx = find(conv(V,[-1,1])==1);
Один из способов - написать цикл. Прошло некоторое время с тех пор, как я использовал Matlab, поэтому простите меня, если мой синтаксис немного не в порядке, но что-то с аналогичной логикой должно работать:
Учитывая ваш вектор V:
idx = [];
for i = 1:(length(V) - 1)
if (V(i) == 0 && V(i+1) == 1)
idx = [idx, (i + 1)];
end
end
Удачи! Сообщите мне, если по какой-то причине это не сработает. Если вы собираетесь выполнять эти действия много раз, вам, вероятно, также следует написать функцию.
Эта точная логика может быть векторизован позволяет максимально использовать встроенную функциональность MATLAB!
Если вам нужно универсальное решение, которое работает для «индекса каждый раз, когда значение изменяется с x на y», используйте этот векторизованный подход:
idx = find( ( V(1:end-1) == x ) & V(2:end) == y ) ) + 1;
В твоем случае
idx = find( ( V(1:end-1) == 1 ) & ( V(2:end) == 0 ) ) + 1;
% >> idx = [10 18 28]
Как и в случае с решением Андера, если вы используете его для индексации, то find - ненужное замедление, просто используйте это
idx = [false, ( V(1:end-1) == 1 ) & ( V(2:end) == 0 )];
Вы можете использовать find для поиска нулей и единиц и использовать intersect для поиска краев, в общем
>> intersect(find(V==0), find(V==1)+1)
ans =
10 18 28
Вы можете заменить 0 и 1 любым произвольным значением. Но если вы имеете дело только с 0 и 1, вы можете упростить его до
>> intersect(find(~V), find(V)+1)
ans =
10 18 28
Это работает, но определенно очень далеко от самого простого способа в MATLAB. Это хорошо для C