爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 10095|回复: 4

[源代码] Python解决实际问题:从时间序列找出特定个数的典型峰

[复制链接]

新浪微博达人勋

发表于 2021-11-12 15:09:14 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
找出典型峰值2.png 找出典型峰值.png


'''
需求缘起:
工作中,常需要从一个时间序列里找出几处高峰,分析为什么高。
用眼睛看、脑子想,是比较费眼、费脑、费时、费力的事,
于是我想用程序自动找,
以下函数用于从一个序列中找出[n1,n2]个峰值的位置
'''
# x是一个一维序列
def findFewPeak(x):
    n=len(x)    # 序列元素数量
    n1=3        #至少需要的峰值数量
    n2=5        #最多需要的峰值数量
   
    # 通过调整步长,获得合适数量的峰值:
    # 一般,步长越长,峰值越少
    for step in range(1,n,1):
        peak_pos=[] # 峰值位置
        for i in range(step,n-step,1):
            zone=x[i-step:i+step+1]
            if x[i]==max(zone):
                peak_pos.append(i)
        
        # 如果此次循环得到的数量合适,就返回:
        if len(peak_pos)>=n1 and len(peak_pos)<=n2:
            return peak_pos
        # 如果最终没找到,返回值就是默认的None,一般都是有的,因为监测曲线都会有振动!


if __name__=="__main__":
    import numpy as np
    import matplotlib.pyplot as plt
   
    # 一个1000个元素的泊松分布随机数序列:
    x=np.random.poisson(5.0,(1000,))
    n=len(x)
    # 找出合适数量的峰值位置:
    peak_pos=findFewPeak(x)
   
    # 画图显示效果:
    plt.figure(figsize=(10,3),dpi=100)
    plt.plot(range(n),x)
    plt.scatter(peak_pos,x[peak_pos],c='red',s=50)
    plt.show()



密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2021-11-13 10:03:35 | 显示全部楼层
我觉得应该就是一个找极值的问题
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2021-11-13 10:47:21 | 显示全部楼层
人可山 发表于 2021-11-13 10:03
我觉得应该就是一个找极值的问题

主要是控制个数
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

发表于 2021-11-13 13:33:43 | 显示全部楼层
这个可以 有时候实验数据找奇异点  纯肉眼挑真费劲。。。。。
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

发表于 2021-11-26 23:13:18 | 显示全部楼层
很不错的一个案例!
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表