python时间序列动图_Python绘制时间序列数据的时序图、自相关图和偏自相关图

原标题:Python绘制时间序列数据的时序图、自相关图和偏自相关图

时序图、自相关图和偏相关图是判断时间序列数据是否平稳的重要依据。

本文涉及的扩展库numpy、pandas、statsmodels一般可以使用pip进行在线安装,如果安装失败,可以到http://www.lfd.uci.edu/~gohlke/pythonlibs/下载相应的whl文件进行离线安装。

另外,绘制自相关图的函数plot_acf()和绘制偏自相关图的函数plot_pacf()还有更多参数可以使用,请自行挖掘和探索。

fromrandom importrandrange

importnumpy asnp

importpandas aspd

importmatplotlib.pyplot asplt

importmatplotlib.font_manager asfm

fromstatsmodels.graphics.tsaplots importplot_acf, plot_pacf

defgenerateData(startDate, endDate):

df = pd.DataFrame([300+i*30+randrange(50) fori inrange(31)],

columns=['营业额'],

index=pd.date_range(startDate, endDate, freq='D'))

returndf

# 生成测试数据,模拟某商店营业额

data = generateData('20170601', '20170701')

print(data)

# 绘制时序图

myfont = fm.FontProperties(fname=r'C:WindowsFontsSTKAITI.ttf')

data.plot()

plt.legend(prop=myfont)

plt.show()

# 绘制自相关图

plot_acf(data).show()

# 绘制偏自相关图

plot_pacf(data).show()

某次运行得到的随机数据为:

营业额

2017-06-01 333

2017-06-02 370

2017-06-03 392

2017-06-04 425

2017-06-05 457

2017-06-06 467

2017-06-07 488

2017-06-08 540

2017-06-09 575

2017-06-10 575

2017-06-11 635

2017-06-12 631

2017-06-13 706

2017-06-14 691

2017-06-15 728

2017-06-16 767

2017-06-17 783

2017-06-18 831

2017-06-19 846

2017-06-20 894

2017-06-21 908

2017-06-22 954

2017-06-23 971

2017-06-24 1011

2017-06-25 1051

2017-06-26 1089

2017-06-27 1120

2017-06-28 1118

2017-06-29 1143

2017-06-30 1181

2017-07-01 1240

相应的时序图为:

cbd6c621ed0e4560948051061f5413b9.png

从时序图来看,有明显的增长趋势,原始数据属于不平稳序列。

相应的自相关图为:

cb5d2815c344427eb827c4b2c17b759b.png

从自相关图来看,呈现三角对称形式,不存在截尾或拖尾,属于单调序列的典型表现形式,原始数据属于不平稳序列。

相应的偏自相关图为:

55f4c01f649647b09ef8cb6e17567c9e.png

从偏自相关图形来看,也不存在截尾或拖尾,属于不平稳序列。

对于不平稳序列而言,要获得平稳序列的方法之一就是进行差分运算,请参考“相关阅读”第一条。

2、董付国老师新作《中学生可以这样学Python》已正式出版,很快就会在各大书城全面上架。

3、董付国老师6本Python系列图书阅读指南返回搜狐,查看更多

责任编辑:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值