QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2707|回复: 0
打印 上一主题 下一主题

ARIMA模型 指数平滑法

[复制链接]
字体大小: 正常 放大

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:30 |只看该作者 |正序浏览
|招呼Ta 关注Ta
当涉及到时间序列数据分析和预测时,指数平滑法是一种常用的方法之一。它是一种简单而有效的平滑技术,可以用于处理具有趋势和季节性的时间序列数据。* y; E$ i7 T2 E
指数平滑法基于以下假设:
- ^& p& f) X; a' M7 i+ a+ ~1.过去的观测值对于预测未来的值更为重要。
# \) R- Y! E+ o2.近期的观测值对于预测的影响程度比过去的观测值更大。$ Q& b" T7 C, I2 c- ?! ~/ e' ?
3.观测值中的随机波动应该被消除,使得预测值更稳定。+ w8 m7 O% c- }( ^9 G9 A
4 K0 a2 ^& ?2 }( d" C% f
指数平滑法有几种不同的变体,其中最常见的是简单指数平滑、二次指数平滑和三次指数平滑。$ X* V* |8 [% ]7 J* o5 U- e) H0 |
& D6 x  p; I1 {6 n3 [- J
4.简单指数平滑(Simple Exponential Smoothing):  H" j+ `7 S; \
简单指数平滑方法将所有观测值视为等权重,并使用一个平滑参数(通常表示为α)来确定各个观测值的权重。具体来说,简单指数平滑法的计算公式如下:
. i7 ]& ~3 y2 O+ s, ^! V3 X, Y; Z9 O$ D* x  d& I& Q9 `: [. p
5.初始值:S₁ = X₁  ?/ }- W: {# D5 l  e. x* t/ O
6.平滑公式:Sₜ = α * Xₜ + (1 - α) * Sₜ₋₁& d9 D  ^% y; ]; H: H; x& B
其中,Sₜ表示时刻 t 的平滑值,Xₜ表示时刻 t 的观测值。$ P1 H0 s% G/ _6 r3 _
7.二次指数平滑(Double Exponential Smoothing):
0 v& S( A* Z5 R- A& P) H1 f  [二次指数平滑法相对于简单指数平滑法,将趋势也纳入考虑。它不仅考虑过去观测值的权重,还考虑了过去观测值的趋势。具体来说,二次指数平滑法的计算公式如下:* U" y, Y7 g* |  H( g" U
) i! ?2 g5 ?1 J2 N8 b9 \6 C# N
8.初始水平值:L₁ = X₁1 g6 a. ^, P& P* o0 v9 F
9.初始趋势值:T₁ = X₂ - X₁- B% {, h7 L% }' j" ^: u
10.平滑公式(水平值):Lₜ = α * Xₜ + (1 - α) * (Lₜ₋₁ + Tₜ₋₁)6 g/ `: q/ g! Y* [1 D- q( A
11.平滑公式(趋势值):Tₜ = β * (Lₜ - Lₜ₋₁) + (1 - β) * Tₜ₋₁
1 G* q# j  @) Y- `* y* G& i2 E其中,Lₜ表示时刻 t 的水平值,Tₜ表示时刻 t 的趋势值,Xₜ表示时刻 t 的观测值,α和β是平滑参数。
! A: v: R0 ?/ I% y7 q- _( e3 N4 m12.三次指数平滑(Triple Exponential Smoothing):
% m5 E& _  V. ]9 n: X# G, T+ i8 P三次指数平滑法是在二次指数平滑法的基础上进一步考虑了季节性的影响。它适用于具有明显季节性模式的时间序列数据。具体来说,三次指数平滑法的计算公式如下:) T9 c& ]) {6 c# J2 _8 a

& `$ l9 c1 }8 p9 i( a. }7 E5 G13.初始水平值:L₁ = X₁
, H. z* k' K8 v  \: s) ]' _8 i14.初始趋势值:T₁ = X₂ - X₁& {) S: y( n% _$ {( @- K4 B& v
15.初始季节性值:S₁ = X₃ - 2T₁ - L₁  b; z& V. F4 V# J2 }6 c4 P- n! G
16.平滑公式(水平值):Lₜ = α * (Xₜ - Sₜ₋₃) + (1 - α) * (Lₜ₋₁ + Tₜ₋₁)! R! ?; n# r+ J( T
17.平滑公式(趋势值):Tₜ = β * (Lₜ - Lₜ₋₁) + (1 - β) * Tₜ₋₁
% }3 S0 b* ~' R' O* n18.平滑公式(季节性值):Sₜ = γ * (Xₜ - Lₜ - Tₜ) + (1 - γ) * Sₜ₋₃6 F8 d, p2 [0 u3 _/ k3 E- y! L( Z1 {
其中,Lₜ表示时刻 t 的水平值,Tₜ表示时刻 t 的趋势值,Sₜ表示时刻 t 的季节性值,Xₜ表示时刻 t 的观测值,α、β和γ是平滑参数。
9 r! I) Q7 h. {  ?# c- Z" G6 F% N( R4 K/ I8 u+ Y
请注意,指数平滑法适用于简单的时间序列模式,例如渐变性趋势或没有明显季节性模式的数据。对于更复杂的模式,如长期趋势、季节性和其他周期性模式,可以考虑使用更高级的模型,例如ARIMA模型。
$ k2 K. u% b/ y& i+ f5 m) fARIMA(Autoregressive Integrated Moving Average)模型是一种常用于时间序列分析和预测的统计模型,它将自回归(AR)、差分(I)和移动平均(MA)三种方法结合在一起。ARIMA模型根据时间序列数据的自相关性和移动平均性来拟合模型,并用于预测未来的数值。ARIMA模型通常用于处理具有复杂模式的时间序列数据,如具有长期趋势、季节性和周期性模式的数据。2 u7 }) X$ p3 L
2 r1 x' R( T6 U. N5 n9 S' K3 h
# 导入所需的库
) i$ o. K6 m/ Cimport numpy as np
$ P4 C. q6 r  ?4 N. V7 M( F& Simport pandas as pd" Z6 _7 v) g; U, S9 I: r

  {3 O# u; N5 Z" x: F# 源数据
) \2 Z# i$ Q3 q  r  U3 Vdf = pd.DataFrame({
* y: n' s& d  R! X' d, M5 n9 a3 e8 x    't': [i for i in range(1, 11)],) L+ u0 t6 K0 B
    'production': [2031, 2234, 2566, 2820, 3006,- y; F, g+ J# A$ p: G
                   3093, 3277, 3514, 3770, 4107],( D  y# k: Z: J  ]* H0 y3 @
})$ ?' K2 Q$ U; j# x; S* B
0 \  H  S% C/ t" z
这段代码创建了一个DataFrame df,包含了时间(t)和产量(production)的数据。
8 T% \" o7 ~- l# 设 alpha=.3,计算一次、二次指数平滑
' a( m- V8 M3 M6 C/ `8 S/ i7 ralpha = .3' P2 n) X0 l. I2 y1 `6 v- R
s1, s2 = [int(df['production'][0])],\
8 y* ^; I9 n" B' J3 y+ p    [int(df['production'][0])]4 T: T+ o! c6 i- {; G/ A5 d

# u8 S& A% I( b" n3 mfor i in range(1, len(df['t'])):
! ~, s9 x; [& X  e7 ^4 n    s1.append(alpha*df['production'][i] + (1-alpha)*s1[i-1])# [+ _. ?, g  j$ S6 h0 K; u
    s2.append(alpha*s1[i] + (1-alpha)*s2[i-1])2 q% R: v+ V- g' w# [0 n
df['s1'] = s1
2 x( Q) g* ~2 `. p% Rdf['s2'] = s2
& ^8 x* d/ w" c7 G* T* F4 e2 `2 r+ Y5 N( ~; q
这段代码使用指数平滑法计算了一次指数平滑和二次指数平滑的值,并将结果添加到DataFrame df中的's1'和's2'列中。
1 d/ y; z) C( ?  `/ U% N* ^, P# 计算过去年的预测值,以及未来年的线性表达式
1 G5 P# m4 P9 wpredict_list = [None]
+ ?# `( S4 w& S0 Z4 x5 F& vfor i in range(len(df['t'])-1):" C- X8 L' e" _; h2 i8 y6 D" U( y8 k
    a = 2*df['s1'][i] - df['s2'][i]
- _9 `  A% t( X* U3 E5 x! o# r    b = (alpha / (1-alpha)) * (df['s1'][i] - df['s2'][i])
, Q# D' {; U$ K0 N, `/ w3 J    predict_list.append(a + b)
; O" U9 q1 k0 w+ \' t7 Z& \) c( v8 f4 V9 z
t = 104 ]! K, |0 [8 j3 e" I7 A
a = 2*df['s1'][t-1] - df['s2'][t-1]% [6 a5 a1 v' n' w" J# T" [" @
b = (alpha / (1-alpha)) * (df['s1'][t-1] - df['s2'][t-1])0 k" O& l$ R" |2 l, L
df['predict'] = predict_list
0 H" P* K' W, z4 G# W5 Z$ r8 Vprint('at =', a)# @( D+ l4 T. i3 R: c  B
print('bt =', b)
, |) _- I0 M: l! [! O3 i+ E6 D( O+ R2 Q$ o7 M9 b( \) V% M
这段代码计算了过去年份的预测值,并给出了未来年份的线性表达式。其中a和b是线性表达式的参数,对应于二次指数平滑法的结果。将过去年份的预测值添加到DataFrame df的'predict'列中,并打印出a和b的值。" K- T/ o0 b  m% H5 o
# 计算未来年的预测值
4 F9 N9 G% \3 K4 G& D+ ]0 gpred_df = df.copy()
; h9 d4 m3 A9 O* U3 tfor i in range(5):! q, M' t( W# v: n8 h( |
    pred_df = pd.concat([pred_df, pd.DataFrame({
! r' Z7 D- B3 P7 l, f2 U' {2 W        't': [10+i+1],
/ l9 u+ J7 g. n        'predict': a + b*i,
/ W$ B9 b. r8 B0 d' _$ Q1 I    })]): L2 \* n3 y$ ]+ Q* o! T
pred_df
5 _1 L) p- P  B% s! ?5 x# z
; k; |$ p( v& ^' `/ W这段代码使用线性表达式计算了未来5年的预测值,并将结果添加到新的DataFrame pred_df中。5 b" Z' o7 z7 i5 e
# 画图# I2 c" W5 P' v# I
import matplotlib.pyplot as plt9 ]4 _! q2 x# _# A0 \( c3 L

& g8 Z1 a0 Q/ i% L' l$ ^, splt.plot(pred_df['t'], pred_df['production'],label='production')2 C" \% w  o4 ?/ _
plt.scatter(pred_df['t'], pred_df['production'])
- r4 B5 ~, Y! h( k/ X- A8 nplt.plot(pred_df['t'], pred_df['s1'],label='s1')6 V9 s7 B) l& {! W7 X
plt.scatter(pred_df['t'], pred_df['s1'])
8 u0 y3 b) F6 P) O6 z* o8 f: r8 v! _  yplt.plot(pred_df['t'], pred_df['s2'],label='s2')
3 C% E6 M7 O# {) D& Yplt.scatter(pred_df['t'], pred_df['s2'])% F  `" ]- g. H$ h$ u
plt.plot(pred_df['t'], pred_df['predict'],label='predict')
8 f2 v" v+ H' G2 _7 g3 [, M( Qplt.scatter(pred_df['t'], pred_df['predict'])6 S; x# l( `: ]( ]' p
plt.legend()* e) v* h# F) t
6 }0 W. A1 X( O6 c/ n/ h7 \
这段代码使用matplotlib库将实际产量、一次指数平滑、二次指数平滑和预测值的曲线图绘制出来。
* ^' h8 p7 r* F7 i3 l  d希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
5 Z$ Y! K' y1 e7 w' P, L
9 B; ~& g) M8 i& \: O1 x. L$ K3 Y" g! @) p# p) D

24.exponential_smoothing.py

1.64 KB, 下载次数: 1, 下载积分: 体力 -2 点

售价: 2 点体力  [记录]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-6-15 12:01 , Processed in 0.349453 second(s), 56 queries .

回顶部