Как пометить, что находится под значением 500? - PullRequest
0 голосов
/ 12 января 2020

Я хотел бы отметить пики, которые меньше 500, звездой или чем-то еще и назвать это «Q-wave», или поставить цветную вертикальную линию в этой точке? enter image description here

Кто-нибудь знает, как это сделать?

Спасибо !!

1 Ответ

0 голосов
/ 12 января 2020

Использование findpeaks. На следующем рисунке и коде показаны некоторые примеры. enter image description here

% Create some data
load sunspot.dat
data = sunspot(1:200,2)*4 + 180;

% Plot the data
plot(data, 'm'); hold on; grid on;
ylim([0,1000]);

% all local maxima
[pks, locs] = findpeaks(data);
plot(locs, pks, 'ro');

% all local minima -- the trick is to invert the data:
[pks, locs] = findpeaks(-data);
plot(locs, -pks, 'bo');

% local maxima greater than 500
[pks, locs] = findpeaks(data, 'MinPeakHeight', 500);
plot(locs, pks, 'r*');

% local minima less than 200
[pks, locs] = findpeaks(-data, 'MinPeakHeight', -200);
plot(locs, -pks, 'b*');

% local maxima less than 400 -- the trick is to apply treshold to the pks
[pks, locs] = findpeaks(data);
locs(pks > 400) = []; % delete unwanted data points
pks(pks > 400) = [];  % delete unwanted data points
plot(locs, pks, 'kV', 'MarkerSize', 5);

legend({
    'data'
    'all local maxima points'
    'all local minima points'
    'maxima greater than 500'
    'minima less than 200'
    'local maxima less than 400'
    });
...