QQ登录

只需要一步,快速开始

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

[建模教程] 时间序列模型 (二):移动平均法

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-5-30 15:04 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。( v  w% C) M% u) W0 t  I8 z" r& i
    ! O! a  {# k, V2 s
    移动平均法
    . l3 |- A+ z- {) \7 o; b7 \移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。  移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。
    9 L- R" D' k' p' X6 O  }+ o3 m2 N1 T8 [0 s. p
    简单移动平均法: U6 p7 r) X  B) d7 u9 b
      f0 q6 y: i, a
    " B4 T* ^: t9 ]% y7 U! \5 k- d
    0 _& @$ T, J/ _2 y
    近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。
    ! k' P4 C6 }) [( M* Y' Q
    - I8 D! n  W) B" y简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。 1 a0 E& w$ n1 v3 K5 k

    & U! Q' J. ], j" G. T# u  w3 v. p例 1  某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。 $ P9 {1 R/ S* X: m  z& X! E9 j

    4 D8 N4 d9 n9 A/ X: n1 `# I: T7 z6 j, Q& ]$ ~7 T

    3 w# w/ l1 s0 {
    + U8 ~( m0 K# ~7 }' p" J( ?( R0 _) X) L- X. c+ P& @: T: L' f
    计算的 Matlab 程序如下:
    8 S6 H+ r0 Z4 Y6 a8 O6 d; |( B
    ) E, H6 R4 J( q4 c( n( w4 Zclc,clear
    ! f6 N& }% ^% b) H6 Ky=[533.8  574.6  606.9  649.8   705.1  772.0  816.4  892.7  963.9  1015.1  1102.7]; m=length(y);   * `6 d& q0 w  d+ v' p9 E1 G! y
    n=[4,5];   %n 为移动平均的项数
    1 O9 P0 L. a0 Y* m* P% h! p, w8 bfor i=1:length(n)    $ l0 N1 o% _- l6 V) ]0 J$ }3 E
    %由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组   
    9 W" j  }  J% I2 O9 U& A) C" n7 q    for j=1:m-n(i)+1         # s, j& J1 v) h: G" z
            yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);     % k, |  |+ ~' h
        end   
    $ q9 l3 m& _2 T4 C) Y! S6 M- h    y12(i)=yhat{i}(end);     , P4 g9 a# H2 }6 t+ P4 E4 i
        s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2));
    $ C  p  K" E2 T* I" X! _, ]end # v# P: v8 ]2 m8 _* d* u; N
    y12,s 1 `; @) K+ T& R) M6 h3 T( U
    ! z% d- N, d- k8 l; O1 z& N2 G
    加权移动平均法- u, U( d& G/ U# }; o
    在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。 7 d3 f3 h$ ^/ g' y$ v
    ! Y1 U( b& q2 U! `0 c4 {* C( g
    0 z+ O( @. G" ^  s
    / [7 B1 C: Y; b4 j* ^; V
    例 2  我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量4 D0 R( V8 y% h/ Q

    9 W4 |* `' Z* B5 P. r7 {* p  Y% j& y. d! K4 W' s0 a  T2 t

    9 ?2 N  U% J, H, x! z+ f/ y  ^" ?6 r6 Q  M

    + F. p1 P- y- K# ~  M8 I
    ' p5 a$ \3 _- N/ l' F. w: a  v6 W! C$ k* s9 @- T% E7 I7 `

    5 L& x9 A3 h& W计算的 MATLAB 程序如下:
    ( x5 V4 O2 g: s5 K  T9 u) o2 ]  G  M, [4 X/ p
    y=[6.35 6.20    6.22    6.66    7.15    7.89    8.72    8.94    9.28    9.8]; 4 V4 Z$ E2 d- ]; d
    w=[1/6;2/6;3/6];
    3 F8 \: Q( ~9 _# h! Dm=length(y);n=3; * H4 J7 D, g0 Y9 w7 Q) c" S
    for i=1:m-n+1     
    7 J8 {; c/ K" E/ t9 _7 _; @    yhat(i)=y(i:i+n-1)*w; : S" B& f2 a4 R' C* P
    end
    + j; O  z4 S) ?, |* a) _7 L, V6 Wyhat
    " C5 E% T% o8 P& Xerr=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m)
    # J! E8 D( h2 _! ^9 S3 x% fT_err=1-sum(yhat(1:end-1))/sum(y(n+1:m)) 8 G' \9 y! m4 E, N& k0 P$ |
    y1989=yhat(end)/(1-T_err)
    / d, q# T% ?- A6 P. T) g& a  V$ A
    在加权移动平均法中,   的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。
    2 Z+ G" ~% b' E& t& v% g( F1 D
    1 q- r: m8 w8 s& `0 K. i趋势移动平均法8 e2 r  k7 C: Z8 m& F3 }
    简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。  一次移动的平均数为
    8 j% Y- F+ J+ \. c
    ) q# U, Z7 ?# F0 \4 m( O
    + Q. \( f$ `; f$ E" B7 @, j
    , ?5 p/ V9 ^+ k9 f8 n  }# }) z" p* Q1 b( f1 r

    $ h" ?3 T+ e! Q
    ; z1 R& Y0 z% r3 e6 y5 s
    9 k  [+ K6 {$ ^* I例 3  我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。 6 p. J' H! N  `9 o+ T6 N1 l
    1 f& U" u  x' M

    . n5 k7 ?: u, Z2 y0 S5 ]/ m; I8 v$ Q( o, I! ~
    解  由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。 , t, d! `0 p- J$ \  u" p
    ; e. L# Y9 C* G6 `/ }! e: o8 u

    ; T$ A9 a7 h% V9 `7 ?( e% }2 M, @5 ~9 O2 x% ^
    计算的 MATLAB 程序如下: / H- x3 s7 s& g. P9 o% j4 e

    ' O6 g" l6 V. p8 M+ M3 p  B% U7 Qclc,clear
    : }9 r! ^  j0 A' Vload y.txt   %把原始数据保存在纯文本文件 y.txt 中 . m  B$ l6 W2 j" v
    m1=length(y);   
    * d7 r) k. m( ^4 I5 _( O4 L9 rn=6;   %n 为移动平均的项数 4 d3 @2 B: v* a2 [
    for i=1:m1-n+1     
    / L- k8 a' a6 i7 R" R( U' X# `$ U) u8 d    yhat1(i)=sum(y(i:i+n-1))/n;
      Q) F. h4 D) t2 T$ yend 6 o# r+ T9 ]: L
    yhat1 4 `% p& G0 M, w% X1 X1 t
    m2=length(yhat1); 5 [# I* u' x; t) B8 Y; q
    for i=1:m2-n+1    ' V$ K  @7 z  s; t) v
        yhat2(i)=sum(yhat1(i:i+n-1))/n;
    6 T" s9 g6 c) g* E9 ^1 D8 c6 F8 Cend 5 F$ I( y0 g' s; i. O$ ]. r
    yhat2   9 g5 G# ?4 v* u2 G: _( _2 x
    plot(1:21,y,'*') ( o/ V, g& r( a2 g3 _* M
    a21=2*yhat1(end)-yhat2(end)
    * x$ |9 D0 S1 e! I# b: cb21=2*(yhat1(end)-yhat2(end))/(n-1) " ?7 k4 C* y4 A$ `3 ~. p
    y1986=a21+b21 ; }# \1 _4 |8 p( c0 ^
    y1987=a21+2*b21
    8 r& o" Y5 C! H& r3 J4 x
    " |1 W3 j/ `. u: y0 R
    / }3 d/ G* W* ^8 q8 r! v2 M# o. W9 Z) p& x5 K
    趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。. v1 o4 r. A  C: w* E4 j, L

    0 h4 C" F6 H4 ?- S: x/ _  x. W# T# `# |4 I1 p3 L

    # y9 x+ F6 p# o4 u$ Q3 e/ t————————————————
    4 j& Y/ m, v, a  \9 ?3 ]3 l! T/ w版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。0 c7 E" @& ]" X. [: o/ S# C- x
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89440426  Z: x1 U( }5 t* }

    : k" n! P2 _. ?
    : b. n/ `* M* J. ]+ ]
    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-11 21:41 , Processed in 0.433574 second(s), 51 queries .

    回顶部