爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 89|回复: 1

[求助] 关于python计算自相关系数的问题

[复制链接]

新浪微博达人勋

发表于 4 天前 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 一大碗年糕 于 2024-11-30 14:00 编辑

目前主要用的python的计算自相关系数的函数是from esmtools.stats import autocorr和from statsmodels.tsa.stattools import acf,但是总感觉速度有点慢(特别是对于分辨率很高的数据),不知道大家都是用什么计算自相关系数的呢?
另外对于同一个数据两个函数算出来的结果貌似不一样?之前一直没怎么仔细关注,如图对于同一个序列的计算结果,acf的结果不一样是什么原因呢


截图 2024-11-30 13-57-21.png
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 前天 15:46 | 显示全部楼层
本帖最后由 taiyang 于 2024-12-2 16:32 编辑
  1. <div style="color: rgb(204, 204, 204); background-color: rgb(31, 31, 31); font-family: Consolas, &quot;Courier New&quot;, monospace; line-height: 19px; white-space: pre;">
  2. </div>
复制代码
def autocorrelation2(x, max_lag):
    """
    计算样本时间序列的自相关系数

    参数:
    x (numpy array): 时间序列数据
    max_lag (int): 最大滞后数,一般建议取为 n/3 到 n/10

    返回:
    autocorr (numpy array): 各滞后数下的自相关系数数组
    """
    n = len(x)
    mean_x = np.mean(x)  # 均值
    s = np.std(x, ddof=0)  # 标准差

    autocorr = np.zeros(max_lag + 1)  

    for j in range(max_lag + 1):
        autocorr[j] = np.sum((x[:n-j] - mean_x) * (x[j:] - mean_x)) / ((n - j) * s**2)

    return autocorr

可以直接算一下
微信图片_20241202154515.png
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

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