finding accurate number of peaks and eleminate unwanted peaks

3 ビュー (過去 30 日間)
sarmad m
sarmad m 2017 年 3 月 20 日
編集済み: Greg Dionne 2017 年 3 月 22 日
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 件のコメント
Adam
Adam 2017 年 3 月 20 日
That seems like a very small MinPeakProminence value

サインインしてコメントする。

回答 (1 件)

Greg Dionne
Greg Dionne 2017 年 3 月 20 日
Try:
findpeaks(sgf,'MinPeakProminence',1.2);
  3 件のコメント
Adam
Adam 2017 年 3 月 21 日
編集済み: Adam 2017 年 3 月 21 日
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 2017 年 3 月 22 日
編集済み: Greg Dionne 2017 年 3 月 22 日
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.

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeDescriptive Statistics についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by