原文链接:http://tecdat.cn/?p=5399

原文出处:拓端数据部落公众号

介绍

对商业周期的分析需要提取时间序列的周期性成分,该时间序列通常也受到诸如潜在趋势或噪声等其他因素的影响。本文介绍了一些在最近的文献中用于从给定序列中提取商业周期的方法。它基于Stock and Watson(1999)在“宏观经济学手册”中关于商业周期的章节。我还介绍了相对较新的方法,如小波滤波器或经验模式分解。由于这篇文章的重点是在R中实现某些过滤技术,我不会涉及数学。相反,我将参考各自的文献。对于这些例子,我使用了实际GDP的季度数据。

names(gdp) <- c("Time","GDP") # 重命名gdp[,"GDP"] <- log(gdp[,"GDP"]) # 取对数

为了直观地了解提取时间序列的周期性成分意味着什么,请查看下图中随时间变化的对数实际GDP的发展情况。


ggplot(gdp,aes(x=Time,y=GDP)) + geom_line(size=.5) + theme_classic() 

数据有明显的增长趋势,逐渐变小。此外,该序列以一种或多或少的常规方式围绕这一趋势波动。该序列与趋势的偏差非常小,这种偏差经常发生,但也有相当大的偏差,这种偏差可能会持续几个时期。后者是与商业周期分析相关的波动。

时间趋于衰退

从一序列中剔除趋势的第一种方法是在时间变量上回归感兴趣的变量并获得残差。这些在下图中绘制,其中线性趋势被移除。

# 可视化ggplot(dat,aes(x=Time,y=Linearly.Detrended)) + geom_hline+ geom_line

这种方法相对有争议,因为它假设存在一个恒定的线性时间趋势。正如我们上面所看到的,鉴于趋势增长率随时间的稳步下降,这种情况不太可能发生。然而,仍然可以假设时间趋势的不同函数形式,例如添加二次项,摆脱趋势。这种方法的另一个缺点是它只能排除趋势,而不能排除噪声,即序列中的非常小的波动。

差分

接下来的方法是采用一阶差分,因为它通常被教导以获得平稳的时间序列。这假设数据是不稳定的。取得一阶差分的结果显示在下图中,其中它也与时间趋势序列进行比较。差分数据在零线附近波动得更多,但它也包含很多噪声。

#可视化g <- melt(dat,,na.rm=TRUE)# 定义绘图函数plotaxis.line=element_line(size=.3,colour="black"), # 设置绘图参数# 绘图plot.cycles(d=g)

Hodrick Prescott过滤器

Hodrick和Prescott(1981)开发了一种滤波器,它将时间序列分为趋势,周期和噪声分量。需要时间序列和平滑参数。下图显示了Hodrick-Prescott滤波器获得的实际GDP的周期性成分值,并将其与线性去趋势序列的值进行了比较。两个序列的行为看起来非常相似,只是HP序列在零附近波动较大,而线性去趋势序列仍然包含趋势的成分。此外,循环HP序列还包括一些类似噪音的成分

#绘图g <- melt(dat[,c(1,4,3)],id.vars="Time",na.rm=TRUE)plot(g)

Baxter过滤器

Baxter和King(1994,1999)提出了一种滤波器,它可以生成与HP滤波器类似的结果,但它可以剔除上面显示的许多类似噪声的行为。它需要序列,周期数量的下限和上限,假定周期发生(plpu),以及平滑因子nfix。文献(参见NBER,Stock和Watson(1999))表明商业周期持续6至32个月。这些值用于指定循环周期的下限和上限。BK滤波器的结果如下图所示。该方法的一个相对序列的缺点是平滑因子导致在序列的开始和结束时样本的丢失。这可能是小样本的问题。

# 绘图dat <- cbind(dat,data.frame( bk))g <- melt(dat[,c(1,5,4)], ,na.rm=TRUE)plot(g )

小波滤波器

Yogo(2008)提出使用小波滤波器从时间序列数据中提取商业周期。这种方法的优点是该功能不仅可以提取序列的趋势,周期和噪声,而且可以更加具体地说明周期发生的周期。然而,由于该方法只能捕获2的幂的周期性,即2,4,8,16,32等,所以没有完全的自由度。

R中的方法实现也很简洁,但在使用之前需要一些额外的数据转换。它需要时间序列的不同版本和分解的深度。

该函数给出了多个序列,必须将它们累积起来cumsum,将它们转换回反映周期性模式的数据。此外,一些序列可以结合使用rowSums。当应该一起分析持续8到16和16到32个周期的周期时,这很有用,如下图所示。小波滤波器产生与BK滤波器类似的结果,因为循环周期的上限在两者中相等,下限仅相差2。

#绘图g <- melt(dat[,c(1,6,5)],id.vars="Time",na.rm=TRUE)levels(g[,2]) <- c("Wavelet","Baxter King")plot.cycles(g,"Wavelet vs. Baxter King")

经验模式分解(EMD)

基于Huang等人。(1998)Kozic和Sever(2014)提出经验模式分解作为商业周期提取的另一种方法。它需要不同的时间序列,边界条件和规则,该规则指定迭代过程在哪个点获得了满意的结果并且可以停止。该滤波器方法的结果与HP,BK和小波滤波器相比有所不同。

 emd <- as.data.frame(emd(xt=diff(gdp[,2]),boundary="wave",stoprule="type2")$imf)g <- melt(dat[,c(1,7,4)],id.vars="Time",na.rm=TRUE)plot.cycles(g,"EMD vs. Hodrick Prescott")

 


最受欢迎的见解

1.在python中使用lstm和pytorch进行时间序列预测

2.python中利用长短期记忆模型lstm进行时间序列预测分析

3.使用r语言进行时间序列(arima,指数平滑)分析

4.r语言多元copula-garch-模型时间序列预测

5.r语言copulas和金融时间序列案例

6.使用r语言随机波动模型sv处理时间序列中的随机波动

7.r语言时间序列tar阈值自回归模型

8.r语言k-shape时间序列聚类方法对股票价格时间序列聚类

9.python3用arima模型进行时间序列预测

拓端tecdat|R语言提取时间序列的周期性成分应用EMD,小波滤波器,Baxter过滤器等相关推荐

  1. python 计量做hp滤波_R语言提取时间序列的周期性成分应用EMD,小波滤波器,Baxter过滤器等...

    原文链接:http://tecdat.cn/?p=5399 介绍 对商业周期的分析需要提取时间序列的周期性成分,该时间序列通常也受到诸如潜在趋势或噪声等其他因素的影响.本文介绍了一些在最近的文献中用于 ...

  2. 拓端tecdat|R语言用LOESS(局部加权回归)季节趋势分解(STL)进行时间序列异常检测

    最近我们被客户要求撰写关于LOESS(局部加权回归)的研究报告,包括一些图形和统计输出. 这篇文章描述了一种对涉及季节性和趋势成分的时间序列的中点进行建模的方法.我们将对一种叫做STL的算法进行研究, ...

  3. 拓端tecdat|R语言逻辑回归(Logistic回归)模型分类预测病人冠心病风险

    最近我们被客户要求撰写关于冠心病风险的研究报告,包括一些图形和统计输出. 相关视频:R语言逻辑回归(Logistic回归)模型分类预测病人冠心病风险 逻辑回归Logistic模型原理和R语言分类预测冠 ...

  4. 拓端tecdat|R语言向量误差修正模型 (VECMs)分析长期利率和通胀率影响关系

    最近我们被客户要求撰写关于向量误差修正模型的研究报告,包括一些图形和统计输出. 向量自回归模型估计的先决条件之一是被分析的时间序列是平稳的.但是,经济理论认为,经济变量之间在水平上存在着均衡关系,可以 ...

  5. 拓端tecdat|R语言线性回归和时间序列分析北京房价影响因素可视化案例

    最近我们被客户要求撰写关于北京房价影响因素的研究报告,包括一些图形和统计输出. 目的 房价有关的数据可能反映了中国近年来的变化: 人们得到更多的资源(薪水),期望有更好的房子 人口众多 独生子女政策: ...

  6. R语言检验时间序列的平稳性(tseries包adf.test):时间序列数据是zoo或xts对象,使用coredata函数提取原始数据,再将其传递给adf.test函数

    R语言检验时间序列的平稳性(tseries包adf.test):时间序列数据是zoo或xts对象,使用coredata函数提取原始数据,再将其传递给adf.test函数 目录

  7. R语言ggplot2时间序列可视化并在特定日期处添加竖线实战

    R语言ggplot2时间序列可视化并在特定日期处添加竖线实战 目录 R语言ggplot2时间序列可视化并在特定日期处添加竖线实战 #仿真数据</

  8. 【R语言实验】基于R语言的时间序列平稳性检验

    一.实验项目名称:基于R语言的时间序列平稳性检验 二.实验目的与要求: 平稳时间序列的概念,平稳性检验的时序图检验方法和自相关图检验方法. 三.实验原理: 时序图和自相关图检验时间序列的平稳性依据: ...

  9. R语言计算时间序列数据的移动平均值(滚动平均值、例如5日均线、10日均线等):使用zoo包中的rollmean函数计算k个周期移动平均值

    R语言计算时间序列数据的移动平均值(滚动平均值.例如5日均线.10日均线等):使用zoo包中的rollmean函数计算k个周期移动平均值 目录

  10. R语言检验时间序列的平稳性:使用tseries包的adf.test函数实现增强的Dickey-Fuller(ADF)检验、检验时序数据是否具有均值回归特性(平稳性)、不具有均值回归特性的案例

    R语言检验时间序列的平稳性:使用tseries包的adf.test函数实现增强的Dickey-Fuller(ADF)检验.检验时序数据是否具有均值回归特性(平稳性).不具有均值回归特性的案例 目录

最新文章

  1. 1073 Scientific Notation
  2. 服膺守善 立德立言——院长王建民教授在清华大学软件学院2020届学生毕业典礼上的赠言...
  3. 滴滴魅族手机人脸识别没有反应_手机UI颜值排名榜单,小米MIUI排到第九,魅族没有上榜...
  4. python 错误处理 assert
  5. KubeVela 上手|让云端应用交付更加丝滑
  6. Java开源权限管理中间件
  7. access 如何使用dolby_Access/VBA/Excel-Access表及字段创建-03
  8. 如何打造139团队(不同层次人员的选择与培养,大型研发团队,大型敏捷开发团队)...
  9. ubuntu系统键盘鼠标失灵的修复方案
  10. Python实现测量平差数据处理
  11. 机器学习之逻辑回归原理
  12. 第11.25节 Python正则表达式编译re.compile及正则对象使用
  13. opencv证件照变更任意底色
  14. 流利阅读 2019.1.22 Theresa May loses big over her Brexit deal
  15. 解决VMware中虚拟机(centos7)无法上网的一种方法
  16. python中re.search()函数的用法
  17. TP5之微信小程序推送模板消息
  18. 人造指针_如何用程式化的阴影和细节制作人造HDR照片
  19. 配置vimrc时各种出错,第n+1行永远报错:unmatched ' 的解决办法!!!
  20. SAP物料的最小订购量、及舍入值的测试

热门文章

  1. android开发我的新浪微博客户端-载入页面UI篇(1.1)
  2. 【Webcam设计】USB摄像头(V4L2接口)的图片采集
  3. 四、基于TCP的服务器端/客户端
  4. 第三季-第1课-程规划与学习方法
  5. 数据--第34课 - 二叉树的深层性质
  6. 五种I/O模型和Java NIO源码分析
  7. Ajax_使用 jQuery 实现Ajax
  8. EasyAndroid基础集成组件库之:EasyReflect 优雅的反射功能库
  9. MATLAB注释快捷键、绘图选项
  10. 转:从内部开始 认识Oracle数据库结构组件