动态信号周期检测

8 篇文章 4 订阅
6 篇文章 9 订阅

一段信号的周期可能会动态变化,下面的代码是根据信号幅度极大值的分布来判断是否存在周期,https://blog.csdn.net/seTaire/article/details/99968948主要是在该方法上做了一点改变。

实验结果:

import librosa
path = "/Users/birenjianmo/Desktop/learn/librosa/input/1你好.wav"
import librosa.display
import matplotlib.pyplot as plt
y, sr = librosa.load(path)
yy = y.tolist()

def gettopdata(y):
    data = []
    for i in range(1,len(y)-1):
        if y[i]>0 and y[i-1]<y[i]<y[i+1]:
            data.append(i)
    return data

def findall(a):
    result = []
    data = []
    for i in range(1,len(a)):
        data.append( a[i]-a[i-1] )
    
    for pos in range(5, len(data)//3):
        for i in range(len(data)-pos):
            if abs(data[i]  - data[i+pos]) < abs(data[i]) * 0.05:
            # if data[i] == data[i+pos]:
                getp = True
                p = [a[i]]
                r = 1
    
                while r < (len(data)-i)//pos:
                    
                    for j in range(pos):
                        if abs(data[i+j] - data[i+pos*r+j]) > abs(data[i+j]) * 0.05:
                        # if data[i+j] == data[i+pos*r+j]:
                            getp = False
                            break
    
                    if not getp:
                        break
                    else:
                        p.append(a[i+pos*r])
                        r += 1
    
                if len(p) > 4:
                    print(pos)
                    print(p)
                    result.append(p)

    return result

if __name__ == '__main__':
    a = gettopdata(yy)
    indexs = findall(a)[0]
    for  i in indexs:
        plt.scatter(i-indexs[0]+1, y[i+1])

    plt.plot(y[indexs[0]:indexs[-1]])
    
    plt.show()
    

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值