峰值

转载:http://blog.163.com/yuyang_tech/blog/static/2160500832013931102250632/

原文出处:http://write.blog.csdn.net/postlist

http://blog.csdn.net/yf210yf/article/details/7453142

———————————————以下为原文———————————————

方法一:

findpeaks 寻找峰值函数
pks = findpeaks(data)
[pks,locs] = findpeaks(data) ------pks 对应峰值,locs 对应峰值位数
[...] = findpeaks(data,'minpeakheight',mph)----mph 设定峰值的最小高度
[...] = findpeaks(data,'minpeakdistance',mpd)----mpd 设定两峰值间的最小间隔数
[...] = findpeaks(data,'threshold',th)
[...] = findpeaks(data,'npeaks',np)
[...] = findpeaks(data,'sortstr',str)
命令findpeaks是用于查找向量中的波峰,即某一个元素比相邻两个元素的值都大。
例如:
a=[1 3 2 5 6 8 5 3];
findpeaks(a),
则返回 3 8
[v,l]=findpeaks(a),
则返回
v=3 8
l=2 6
如果a为一个矩阵,则按照列的搜索顺序列出波峰的值和位置。更详细的可以参考help findpeaks

缺点:只能找波峰值,无法找波谷值。

 

方法二:

IndMin=find(diff(sign(diff(data)))>0)+1;
IndMax=find(diff(sign(diff(data)))<0)+1;

其中的,

IndMin, data(IndMin)对应的是波谷点的数据
IndMax,data(IndMax)对应的是波峰点的数据

例如:

>> a=[1 3 2 5 6 8 5 3]

a =

     1     3     2     5     6     8     5     3

>> IndMax=find(diff(sign(diff(a)))<0)+1

IndMax =

     2     6

>> a(IndMax)

ans =

     3     8

>> IndMin=find(diff(sign(diff(a)))>0)+1

IndMin =

     3

>> a(IndMin)

ans =

     2

原文地址:https://www.cnblogs.com/xiaoxuesheng993/p/7649006.html