0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

时间序列分析的定义

数据分析与开发 来源:一个数据人的自留地 作者:数据人创作者联盟 2022-03-16 16:17 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

01

时间序列分析的定义

1.1

概念

首先,时间序列定义为在一定时间间隔内按时间顺序测量的某个数量。时间序列分析是指将历史数据分解为四部分来看——趋势、周期、时期和不稳定因素,然后综合这些因素,提出预测。时间序列分为平稳序列和非平稳序列两大类。平稳序列是不存在趋势只存在随机性的序列,非平稳序列则是包含趋势、季节性和随机性的序列。

从最广泛的形式来说,时间序列分析是关于推断过去一系列数据点发生了什么,并试图预测未来会发生什么。时间序列分析试图了解过去并预测未来。

1.2

分类

通常,时间序列通常包含以下类型:

1、趋势-趋势是时间序列中一致的方向性运动。这些趋势将是确定性的或随机的。时间序列在长时间内呈现出来的长期上升或下降的变动;

2、季节性变化-许多时间序列都包含季节性变化。在代表业务销售或气候水平的系列中尤其如此。我们经常看到商品的季节性变化,特别是那些与生长季节或年度温度变化有关的商品(例如天然气)。

3、序列依赖性-时间序列(尤其是金融序列)最重要的特征之一就是序列相关性。当时间上相互靠近的时间序列观测值倾向于相互关联时,就会发生这种情况。

02

时间序列分析的步骤

时间序列预测的步骤是:

fe4a328e-9752-11ec-952b-dac502259ad0.jpg

在开始平稳性检验步骤之前,我首先想和大家分享的是平稳性检验的目的。平稳性检验为了确定没有随机趋势或确定趋势,否则将会产生“伪回归”问题.伪回归是说,有时数据的高度相关仅仅是因为二者同时随时间有向上或向下的变动趋势, 并没有真正联系.这样数据中的趋势项,季节项等无法消除, 从而在残差分析中无法准确进行分析。

2.1

平稳性检验

(一)图示法

平稳性指的是期望不变,方差恒定,协方差不随时间改变,协方差只依赖于K这个时间跨度,不依赖于时间点t本身。

fe63d856-9752-11ec-952b-dac502259ad0.jpgfe70d31c-9752-11ec-952b-dac502259ad0.jpgfe922b8e-9752-11ec-952b-dac502259ad0.jpg

给定这些假设前提的目的是便于后续技术上的处理。根据时序图粗略来判断序列是否平稳,平稳时序图的特征为围绕均值不断波动,而非平稳时序图表现为在不同时间段具有不同的均值。图a为平稳时序图,图b为非平稳时序图。

fea3d15e-9752-11ec-952b-dac502259ad0.jpg

然而仅依靠图像判断时间序列的平稳性,肯定是不精确的,因此需要进行单位根检验(DF检验和ADF检验)进一步判断。

(二)单位根检验

1、DF检验

fecc97ec-9752-11ec-952b-dac502259ad0.png

fee33434-9752-11ec-952b-dac502259ad0.png

(原假设 H0:序存在单位根 ,即参数δ=0)

检验时间序列的平稳性,一般可通过检验带有截距项的一阶自回归模型:

fef8d03c-9752-11ec-952b-dac502259ad0.png

对上式可通过进行普通最小二乘法的t检验完成(t检验的原假设:H0:βj=0。即若P值<0.05,则拒绝原假设,证明δ≠0,序列平稳。

2、ADF检验 因DF检验假设ut为白噪声,序列为一阶自回归的模型,但实际上随机干扰项并非为白噪声序列,且序列并非为一阶自回归生成,因此用普通最小二乘法进行估计的t统计量会受到无关参数的影响,导致DF检验无效。

如果时间序列包含有明显的随时间变化的某种趋势,DF检验必须保证能够剔除这种趋势,否则时间趋势的成分会进入ut,导致ut非白噪声序列,进而偏离了最初的假设。因此形成了ADF检验。ADF检验是由下面3个模型完成:

ff046ff0-9752-11ec-952b-dac502259ad0.png

其中t为时间变量,代表序列随时间变化的趋势。

模型的检验原理同DF检验,即t检验;检验顺序为(3)、(2)、(1);三个模型全部检验通过,才能证明该序列是平稳时间序列。

2.2

时间序列常见的三种模型

序列通过平稳性检验后,就可以建立时间序列模型了,当序列不平稳时,对序列进行差分或者取对数处理。对时序数据进行差分处理,例如在R语言的“diff”函数可确定(P值<0.05,则拒绝原假设,序列不存在单位根,经1阶差分后,序列平稳)。

对一个时间序列预处理后检验出该序列为平稳时间序列说明该模型有提取信息的价值,就要进行下一步的模型建立来拟合该模型然后做出预测。下面介绍拟合时间序列的三个重要模型。

(一)AR(p)模型

自回归模型(Autoregressive model,简称AR模型),用同一变数例如x的之前各期,亦即x1至xt-1来预测本期xt的表现,并假设它们为一次线性关系。因为这是从回归分析中的线性回归发展而来,只是不用x预测y,而是用x预测 x(自己);所以叫做自回归。

AR(p)模型简记形式如下: ff1bf1c0-9752-11ec-952b-dac502259ad0.png 其中p为自回归阶数。Φ0=0称为中心化AR(p)模型。p阶自回归模型的自相关系数拖尾,偏自相关系数p阶截尾。

(二)MA(q)模型 MA模型(moving average model)移动平均模型,简记形式如下:

ff37d048-9752-11ec-952b-dac502259ad0.png

其中q为移动平均的阶数。q阶移动平均模型自相关系数q阶截尾,偏自相关系数拖尾。

(三)ARMA(p,q)模型 自回归滑动平均模型(Autoregressive moving average model,简称:ARMA模型)。是研究时间序列的重要方法,由自回归模型(简称AR模型)与移动平均模型(简称MA模型)为基础“混合”构成。它比AR模型法与MA模型法估计更精确,但其参数估算比较繁琐。ARMA(p,q)模型简记形式如下:

ff46686a-9752-11ec-952b-dac502259ad0.png

当q=0时,ARMA(p,q)模型就退化成了AR(p)模型;

当p=0时,ARMA(p,q)模型就退化成了MA(q)模型;

ARMA(p,q)模型具有自相关系数不截尾,偏自相关系数也不截尾的性质。

2.3

模型的选择与定阶

了解了时间序列的三种常见模型后,应该如何选择模型并确定模型的阶数呢?通常使用ACF与PACF图判定法。

说到时间序列分析,一定离不开自相关函数(auto-correlation function,ACF)和偏自相关函数(Partial auto-correlation function,PACF),ACF可以提供具有滞后值的任何序列的自相关值。

简单来说,它描述了该序列的当前值与其过去的值之间的相关程度。时间序列可以包含趋势,季节性,周期性和残差等成分。ACF在寻找相关性时会考虑所有这些成分。直观上来说,ACF 描述了一个观测值和另一个观测值之间的自相关,包括直接和间接的相关性信息。

PACF可以提供残差(在去除了之前的滞后已经解释的影响之后仍然存在)与下一个滞后值的相关性。因此,如果残差中有任何可以由下一个滞后建模的隐藏信息,我们可能会获得良好的相关性,并且在建模时我们会将下一个滞后作为特征。

讨论完两个重要函数后,就成功了一半,接下来就是选择模型和确定阶数了,由此引入两个词:截尾和拖尾。

截尾是指时间序列的自相关函数(ACF)或偏自相关函数(PACF)在大于某个常数k后快速趋于0为k阶截尾;拖尾是ACF或PACF始终有非零取值,不会在k大于某个常数后就恒等于零(或在0附近随机波动)。趋于0在实际分析过程中通常被处理为在2倍标准差之内。

ff5ebab4-9752-11ec-952b-dac502259ad0.png

ff710ac0-9752-11ec-952b-dac502259ad0.png

以上面两张图为例,ACF拖尾,PACF一阶截尾,因此可以选择AR(1)模型进行拟合,说到模型拟合,各位统计学前辈早已为我们总结好以下规律:

ff84bc32-9752-11ec-952b-dac502259ad0.png

2.4

模型的确定与检验

通过以上内容,大家对时间序列的三种模型有了初步了解。那么应该如何确定最优模型呢?通常有以下几点:

(1)同一种模型,在尽可能描述数据信息的前提下选择低阶模型,阶数越高,模型会越复杂

(2)高阶AR(p)、MA(q)模型与较低阶ARMA(p,q)模型之间选择较低阶ARMA(p,q)模型

(3)合适模型的残差应满足均值为零的正态分布,而且任何滞后阶数的残差相关系数都为零。

接下来分享的是残差检验的方法:

方法一:通过绘制正态分布的QQ来检验:图像近似为过原点的一条直线,则残差服从正态分布且均值为零。该步骤可通过R语言的“qqnormt”函数实现。如下图:

ff973e34-9752-11ec-952b-dac502259ad0.jpg

方法二:通过R语言的“Box.test”函数实现该检验,若P>0.05,接受原假设,即任何滞后阶数的残差都不相关,残差检验通过。

03

示例分享

回到开头的例子,当小毛同学拿到数据后首先应该绘制销售额随时间变化的曲线,观察数据的整体趋势,如果有季节性趋势,应该利用差分或者移动平均的方法消除季节因素,接下来在消除增长趋势,然后利用单位根检验来检验数据的平稳性,最后利用数据的ACF和PACF函数确定阶数和模型。

其实在这一步有一种偷懒的办法就是利用R语言中的auto.arima”函数可自动筛选出p,q,但还是希望大家能够了解背后的逻辑。模型确定好之后可以利用R语言中的forecast函数预测未来N期的销量,至此小毛的预测工作终于可以告一段落了。

本次分享到此结束,欢迎大家批评指正~

审核编辑:何安

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 序列
    +关注

    关注

    0

    文章

    70

    浏览量

    20133

原文标题:时间序列分析浅谈

文章出处:【微信号:DBDevs,微信公众号:数据分析与开发】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ATA-D60090功率放大器在时间调制序列生成中的应用

    利用计算机生成波束扫描所需的的波束扫描的时间编码序列。根据时间编码序列,任意信号发生器产生的方波信号通过功率放大器产生控制电压信号。
    的头像 发表于 11-30 14:27 273次阅读
    ATA-D60090功率放大器在<b class='flag-5'>时间</b>调制<b class='flag-5'>序列</b>生成中的应用

    时间频率标准源有什么功能

    时间频率
    西安同步电子科技有限公司
    发布于 :2025年11月04日 17:58:08

    如何评估协议分析仪的性能指标?

    ,避免订单延迟。 IoT网络:大量小包(如CoAP协议)需高包处理速率防止堆积。 延迟(Latency) 定义:数据包从进入分析仪到输出结果的耗时(纳秒/微秒级)。 评估方法: 硬件时间戳:使用支持
    发表于 07-18 14:44

    构建自定义电商数据分析API

      在电商业务中,数据是驱动决策的核心。随着数据量的增长,企业需要实时、灵活的分析工具来监控销售、用户行为和库存等指标。一个自定义电商数据分析API(应用程序接口)可以自动化数据提取和处理过程,提供
    的头像 发表于 07-17 14:44 402次阅读
    构建自<b class='flag-5'>定义</b>电商数据<b class='flag-5'>分析</b>API

    VirtualLab Fusion应用:多反射系统的非序列建模

    序列光学系统,特别是那些非序列性来自组件内部多次内部反射的系统,具有一系列特定的挑战。将这样的系统分解成一个顺序等价的系统通常非常不方便,而且总是不切实际的。因此,拥有一个稳定的非序列建模策略
    发表于 06-12 08:49

    HarmonyOS实战:自定义时间选择器

    前言 最近在日常鸿蒙开发过程中,经常会使用一些时间选择器,鸿蒙官方提供的时间选择器满足不了需求,所以自己动手自定义一些经常会使用到的时间选择器,希望能帮到你,建议点赞收藏! 实现效果
    的头像 发表于 06-09 15:51 490次阅读
    HarmonyOS实战:自<b class='flag-5'>定义</b><b class='flag-5'>时间</b>选择器

    时间间隔测量分析仪特点总结

    时间频率行业,时间间隔测量是不可缺少的一部分,选择一款合适的时间间隔测量仪就会显得尤为重要,今天我们来分析一下时间间隔
    的头像 发表于 05-08 11:29 374次阅读
    <b class='flag-5'>时间</b>间隔测量<b class='flag-5'>分析</b>仪特点总结

    请问DLP4500的使能时间如何缩短?

    我这边需要投射一组21张图配合相机采集后生成点云,然后想要实现实时性效果,但是每次投射一组序列前都需要使能一遍,耗时大概四百多毫秒,这个时间太长了,有没有办法缩短?如果采用序列连续模式,采图顺序可能会出现混乱,所以只能用单次模
    发表于 03-03 07:44

    HarmonyOS NEXT 原生应用/元服务-性能分析基础耗时分析Time分析

    在录制前单击 指定要录制的泳道: User Trace:用户自定义打点泳道,基于时间轴展示当前时段内用户使用hiTraceMeter接口自定义的打点任务的具体运行情况。 ArkTS
    发表于 02-25 14:31

    DLP3010EVM-LC无法按照设定好图形序列进行顺序投影,怎么解决?

    当增大投影曝光时间的时候,dlp投影的只能够投出第一幅图案,而无法按照设定好的图形序列逐次进行投影后续图案。
    发表于 02-17 07:03

    使用BP神经网络进行时间序列预测

    使用BP(Backpropagation)神经网络进行时间序列预测是一种常见且有效的方法。以下是一个基于BP神经网络进行时间序列预测的详细步骤和考虑因素: 一、数据准备 收集数据 :
    的头像 发表于 02-12 16:44 1268次阅读

    FRED应用:二阶鬼像分析

    一个长的多阶次的杂散光分析。本文介绍了一个脚本,可以在一个导入的序列设计中对初级鬼像路径进行自动分析。我们首先来讨论合理地设置分析中导入的序列
    发表于 01-10 08:55

    信号上升时间与带宽的关系 一文看懂!!!

    0 一、脉冲信号的上升时间 脉冲信号的上升时间是指 脉冲瞬时值最初到达规定下限和规定上限的两瞬时之间的间隔,除另有规定外,下限和上限分别定义为脉冲峰值幅度的10%和90%。在控制领域中,上升
    的头像 发表于 01-06 17:56 2478次阅读
    信号上升<b class='flag-5'>时间</b>与带宽的关系   一文看懂!!!

    如何使用DFT进行频谱分析

    使用离散傅里叶变换(DFT)进行频谱分析是一个将信号从时域转换到频域,并分析信号在频域上的特性的过程。以下是使用DFT进行频谱分析的基本步骤: 一、理解DFT的基本概念 定义 :离散傅
    的头像 发表于 12-20 09:16 2684次阅读

    zeta的定义和应用 如何使用zeta进行数据分析

    Zeta(ζ)电位是描述悬浮粒子在液体中移动时所产生的电位差的一个物理量,以下是对其定义、应用以及如何进行数据分析的详细解释: Zeta电位的定义 Zeta电位是通过理论推导和实验测量得到的,它反映
    的头像 发表于 12-19 18:10 6706次阅读