finding accurate number of peaks and eleminate unwanted peaks

3 vues (au cours des 30 derniers jours)
sarmad m
sarmad m le 20 Mar 2017
Modifié(e) : Greg Dionne le 22 Mar 2017
HI
I'm trying to find peaks in this data :
the actual data has 10 peaks as shown in the image below (peaks are in rectangle)
. I applied sgf filter got the peaks below
order = 7;
framelen =15;
x=data;
lx = 34;
sgf = sgolayfilt(x,order,framelen);
plot(x);
hold on;
plot(sgf);
sgf=-sgf;
[pks_smoothed,locs_smoothed,widths_smoothed,proms_smoothed] = findpeaks(sgf,'MinPeakProminence',0.05);
pks_smoothed = -pks_smoothed;
plot(locs_smoothed,pks_smoothed,'g*');
text(locs_smoothed+.02,pks_smoothed,num2str((1:numel(pks_smoothed))'))
it detects many unwanted peaks how can I find the required peaks accurately and get rid of unwanted peaks ?
  1 commentaire
Adam
Adam le 20 Mar 2017
That seems like a very small MinPeakProminence value

Connectez-vous pour commenter.

Réponses (1)

Greg Dionne
Greg Dionne le 20 Mar 2017
Try:
findpeaks(sgf,'MinPeakProminence',1.2);
  3 commentaires
Adam
Adam le 21 Mar 2017
Modifié(e) : Adam le 21 Mar 2017
Well, you can just set the 'NPeaks' property to 10, but whether it picks the 10 you want or not is another matter. You may still have to tweak around with some of the other options for findpeaks.
Greg Dionne
Greg Dionne le 22 Mar 2017
Modifié(e) : Greg Dionne le 22 Mar 2017
An alternative is to perhaps take the output of your widths_smoothed and prom_smoothed and come up with some heuristic that matches the most of the peaks you care about then filter out the rest based upon that somehow. Some of your peaks look kind of "flat". Maybe use a combination of medfilt1() and diff() to identify the edges.

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by