QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3362|回复: 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 |邮箱已经成功绑定
    移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。
    0 X2 @2 `9 z5 Z+ _( o8 K0 n) m6 V: t
    移动平均法3 F& [9 u+ E& n5 n8 @
    移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。  移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。
    1 A0 d0 @0 z" h+ ~! Y3 O6 C9 X9 v9 f* x* f2 s0 U% g
    简单移动平均法
    ' U& [) ?: H& G! ?$ V2 X5 w# E2 p8 a& n' ?+ F

      J- X# `" i; k! c, T% H! `1 {' x0 C2 J. @. g& G
    近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。
    1 n6 \, H, v; t" W6 H9 F) D0 Y& A, X) D3 Z$ n6 U2 D0 A- t
    简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。
    0 W' |) w+ h" M: U: v* j: e
    % d  z7 M: {$ @9 ^4 v+ `例 1  某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。 1 d4 Y; k$ m" V9 I( F( E: x

    ( ~0 [; y9 ~3 z  l' R# M. X- S/ N: ~& ?* g

    3 n# \0 Q5 d+ ]/ }0 L5 h+ h: U6 r6 o" W. x% `& ?9 {

    ; M0 q0 c5 Z6 q2 `) N$ o计算的 Matlab 程序如下:
    ( g6 R) M& W9 u1 I) i/ R- X3 ?' \+ g' j+ ^, i: |0 Q  L6 f  y2 ^& ?5 n
    clc,clear 9 s6 z1 N% E3 f* J
    y=[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);   * z5 C6 d# _7 J8 T0 e5 u
    n=[4,5];   %n 为移动平均的项数 ( b' a% i. o1 m: b4 H8 K7 o" l
    for i=1:length(n)    , k% q. h" l6 x( F
    %由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组    # A% c/ P. F$ @. f
        for j=1:m-n(i)+1         
    2 F/ j( \( L- N5 _3 t3 J        yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);     
    1 A3 N4 \& q9 b( W    end   
    & A9 i/ ~$ O5 g' A    y12(i)=yhat{i}(end);     
    . v) e2 T! j- a! Q    s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2));
    + T( d! j1 l; \; e2 h  |. eend
    3 K3 c* g( [1 f# u6 S% ky12,s 7 Z" Y, L4 C6 {& }8 z' z
    & ~% W& b2 z# f' X9 \/ ]" C( {
    加权移动平均法
    3 ^9 j% @7 b: ^8 J/ S+ }在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。
    & f, T. ~' j8 E+ ?- w& c& p, L* {
    4 [+ ^) L! ^7 V. ]3 u8 f, `1 J" e

    3 Y8 l) ^3 M- G2 M9 O5 e7 g例 2  我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量. ]7 _# s+ }8 e2 y- Q. f  f6 ]

    " ?+ ?( O$ d' O! T
    2 T! m5 h3 i1 y# K* t& z! e' X
    3 K$ r  _$ Y! b  c5 F' c2 H, Y, j# ]0 b/ P8 m; ]; J$ W7 j

    7 a' X/ m, G; |, C. m  |
    2 x! h- w0 g& l. u5 H) O
    # o1 u. b2 h: T6 h( Y6 ]; g0 l7 a- f+ k; o
    计算的 MATLAB 程序如下:
    3 O# }* l5 j7 P3 O3 S4 Q! l
    / i5 A- C1 w5 i( q" e: R/ jy=[6.35 6.20    6.22    6.66    7.15    7.89    8.72    8.94    9.28    9.8];
    . m. g, P+ c+ x8 Z  l* x' Kw=[1/6;2/6;3/6]; * L0 t, G: r# S* ^
    m=length(y);n=3; 2 v3 \. `' v! _1 N
    for i=1:m-n+1       n0 q6 s% x4 N" M0 @7 l1 a% L
        yhat(i)=y(i:i+n-1)*w;
    3 D1 ^& ~7 p: d7 ]3 q$ _7 J4 Jend
    / Q" A* d6 r* W/ a! ?8 Y, Jyhat
    8 y) ^7 d8 l7 S3 _err=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m)
    ; b( y; r. T. S) n1 i) ]& U1 n: m! RT_err=1-sum(yhat(1:end-1))/sum(y(n+1:m))
    ) D- s( y% a# L( ]" h* Ly1989=yhat(end)/(1-T_err)
    1 [. Q4 A: R* Q& d: P) _
    + G3 V3 L7 m/ o+ q/ J5 d) ^$ \ 在加权移动平均法中,   的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。 ( \0 I# }7 I4 O. I# Q/ x: }

    1 |! \8 g$ S2 Q- ^! F: l趋势移动平均法
    9 j9 J, a* f( S# b简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。  一次移动的平均数为
    9 i4 z$ S+ T0 W% y* D, _, K( U3 l5 _" m  r
    6 G! _0 D6 m3 b, V

    " ]+ k5 l3 n  U* j* p5 s# Z
    ) ^2 c, T+ s! H; p
    - L  V% O' C5 v1 U4 R! N" H/ r2 p4 A  L% R4 b' ~1 r+ {

    8 k6 T; K- x& W! _) V例 3  我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。 / \7 n8 q. P. Y, k" {% X2 S2 d

    # _  x' `+ c' F3 S% e- ?/ U% y$ }' w3 ~# P; |+ ^
    0 |+ T7 G4 u, }' }2 [. w
    解  由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。 ( j& A' A; s$ m3 U! I  J( E

    # J# p2 L5 M3 E! M! L# ^2 X  {. Z9 l' R. Y! y, m3 o
    ! |1 b# [  I* d' k  O6 [
    计算的 MATLAB 程序如下:
    ' |( m6 t5 {: j  P1 y) a! {8 C) h# [* j8 Z
    clc,clear
    # s% X( d& q$ o1 s* Hload y.txt   %把原始数据保存在纯文本文件 y.txt 中 " L% n( x; m7 n: m2 c0 t
    m1=length(y);    : G; Q+ k# `8 g9 K5 `1 x( ?
    n=6;   %n 为移动平均的项数 - P- M8 p5 }) q7 n2 N7 K: K& U% T
    for i=1:m1-n+1     
    " ]9 N8 e8 p& V8 u    yhat1(i)=sum(y(i:i+n-1))/n; 3 V& _6 h. j2 S' D7 u/ G, P" I
    end 5 j. W# f& t8 r  B/ y" a
    yhat1 # k' @! E: T+ b% C; U- ^
    m2=length(yhat1);
    $ [+ h, `$ m$ w1 K! S' {/ u, F7 rfor i=1:m2-n+1   
    # b3 F, H+ }) u    yhat2(i)=sum(yhat1(i:i+n-1))/n;
    ' L$ e8 v2 T$ N& ~6 N6 U# v. s& Jend ; ^/ d( E" @* G, M# q# t; T  H
    yhat2   ! X; u4 w) ^) |. V
    plot(1:21,y,'*') 6 f* t- k- F, c2 p
    a21=2*yhat1(end)-yhat2(end)
      e$ S( H  g/ G* C) |8 eb21=2*(yhat1(end)-yhat2(end))/(n-1) : i- j2 g( w% }4 N
    y1986=a21+b21 " T1 U; Z, B4 O0 d4 M) c& v
    y1987=a21+2*b21 + T) \  v2 Y/ b. `; f8 ]

    7 F, Q* w/ ^3 j9 J5 ?+ j) S, w! j0 G

    " y; L( Z$ e# s趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。2 G, }6 i% k# C. T) g- ^3 }0 P

    " R  ~' C' p' U9 U& v' k0 W
    ) g( r/ i1 ]5 w2 Q, a4 n9 s  |! W  N& T5 I: H8 P' g
    ————————————————
    7 s" ~8 n) |; U; e6 ^版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    - T9 U! r6 E; l6 P- c: `4 b原文链接:https://blog.csdn.net/qq_29831163/article/details/89440426
    $ {  u, g4 {* C# }( t: `# \* D8 g1 g! j# @1 D

    9 N( }" l& W6 ?- {# v& w
    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-14 22:20 , Processed in 0.614597 second(s), 51 queries .

    回顶部