QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3308|回复: 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 |邮箱已经成功绑定
    移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。
    ' D- `! c2 V0 N; g
    : \! `1 k7 N$ l1 G/ P1 V- Z0 ^移动平均法
    5 {0 ~: p% M2 b  F; |移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。  移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。
    8 m. L% N5 B7 e- F% T4 U0 R: @- f" v' I4 C, z* m+ R
    简单移动平均法) }/ p3 X. M6 X6 j* y5 G+ N% ^
    ) h- g: R" J5 e& i/ }: N0 i
    4 N/ d) a) c6 j4 k
    , U  \6 I' A- W5 I, _5 r
    近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。
    , n: p, q! V% L  @4 q- R1 Y2 D% |% `, ]. r; G' a1 f- m* p% ^  j8 D, t
    简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。
    9 J6 ]" ]' `6 W; L! ~. d0 ^
    & R$ L" q( t, C  K例 1  某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。 ) o0 Z; N- R9 a4 E: E9 z( R

    5 e, y! ?" Q1 _  j
    7 C- X0 Y7 [: d6 U- v/ D: ~) B+ I) O* ^) v' ]
    ( R8 O; R9 M: q1 ~; l" D+ X

    4 J! h$ g0 t: j6 T9 a计算的 Matlab 程序如下: 7 E: E* V+ W4 J% k# A

      S# `0 o$ `4 S- k: Qclc,clear ! a& ^. Y+ W! ~9 {( I1 V) f$ }
    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);   
    : f) r/ I  E3 q n=[4,5];   %n 为移动平均的项数   \: }" b+ w8 S/ s* ~& A! L
    for i=1:length(n)   
    ! F3 b, i  z9 @' t# I- i: O %由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组   
    ; O& K/ |% q; D4 [* W! `& p    for j=1:m-n(i)+1         
    8 v* ^+ h5 {0 g6 p2 f9 `        yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);     9 @7 Q; d* ]$ [: b
        end    : @* o) H) h% ?, g
        y12(i)=yhat{i}(end);     
    ! ^# G- {% q0 K" l+ X% S- V1 g3 J0 }    s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2)); 6 p% W" g' r) {) Q
    end
    ' h6 i5 i& o. V/ W8 S/ hy12,s 9 I5 `' q* P0 Z- O. z
    ' [& c. ?7 m  l9 r4 o* G
    加权移动平均法
    $ J' `; u3 i0 J9 ?4 b( V在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。
    0 f' L+ t0 F& U  I. S. o9 o
    - [) p) }; I+ j: d( Y8 l4 n: `
      A3 l- w6 N+ P( f( N
      _1 E! U) [) v' s, N: ?$ h% \3 i例 2  我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量) R, B) m# C. j0 W! Q3 Z1 Q' |& K
    3 K7 V( k( ^+ ?4 d
      ]) u9 Y1 ?/ }; E' d# n8 H
    $ _7 ~- }5 ?3 I! C; l. g

    ; r2 M8 T+ t6 E  ]) }4 q% w; Q6 j3 K2 h' H
    , k( u% @" h3 x' Q( ?. H- O9 h7 \0 x

    # H- q9 g$ U/ I$ E; o
      D" G" f, p! b0 e6 v: `1 N) \计算的 MATLAB 程序如下: 9 K8 g/ v$ X1 ]4 A6 v: t

    ) E) n' w) M8 Y/ {y=[6.35 6.20    6.22    6.66    7.15    7.89    8.72    8.94    9.28    9.8];
    2 M3 A/ C1 d: I* v! gw=[1/6;2/6;3/6];
    - b* r9 b0 S3 z6 q+ H; A- qm=length(y);n=3;
    ( ^; p, E$ N. t! A5 {- r: Bfor i=1:m-n+1     
    8 o. k6 M& N+ S& S+ y/ H9 y    yhat(i)=y(i:i+n-1)*w;
    / M; l& F3 t; S5 lend
    5 }1 n7 t& z, X1 ^" ?yhat
    $ p- r/ S$ d. Q* }! x0 T  \3 Derr=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m) 2 L+ B/ c7 X7 S1 Q* _5 S% Y: T/ o# V
    T_err=1-sum(yhat(1:end-1))/sum(y(n+1:m)) $ F* d/ B& J0 _* N+ U, s& b# r
    y1989=yhat(end)/(1-T_err)7 W0 B" C* L/ S8 }3 @$ w4 o

    4 Z% U; G* G! b6 O 在加权移动平均法中,   的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。
    0 E" R9 ]; G9 ], M1 l6 \' U2 }0 X7 ?$ N, Z2 Q9 K  m: i' y4 t1 A
    趋势移动平均法: A/ G4 j% I; u/ a" R
    简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。  一次移动的平均数为
    * C6 z2 w4 \9 M- n+ K. s! R2 t  z$ @( E5 r6 A- d

    , Y. G2 A8 y* v  g) I' R" _& g6 P6 L

    # i, t# q' F* j! _% ~- _
    ( X  k" V8 b) L% U" q& W" X& `9 j1 e: d
    0 w# w/ T3 ]  _* W- g8 C7 }
    例 3  我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。
    # M. l9 d0 v8 S2 g0 o  c' H2 Z
    2 n  s5 e4 ~2 A+ v) ]& j4 |  s! B$ ?2 j0 K* u& l+ x1 z9 }1 i  B

    : U1 q; G8 |: e, k/ Y解  由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。
    # T  \* _: c! y3 s. ^; d/ J% d4 z& F

    " j! F0 ^. B3 ~! p: g% w
    2 Z* ]3 \2 C; O) l- H* t. v8 R6 X计算的 MATLAB 程序如下: : G7 T* n" J, K0 l1 m8 Y

    . C/ @8 l! A2 d& v& _clc,clear
    * M3 ]. g1 F2 q& K; v3 wload y.txt   %把原始数据保存在纯文本文件 y.txt 中
      B$ {6 D1 T" u2 J- t4 S" _m1=length(y);    0 }2 y1 V' Q1 C8 U
    n=6;   %n 为移动平均的项数 - y+ X9 i, O2 _/ F4 ?
    for i=1:m1-n+1     2 \; R3 P# a9 ?3 d7 Q" b
        yhat1(i)=sum(y(i:i+n-1))/n; , Y! u4 F) _6 i
    end : m3 d0 m# g$ V
    yhat1 * c, p$ r$ v9 m; M: S6 ^
    m2=length(yhat1);   x: o' a! r) M+ f/ v8 H
    for i=1:m2-n+1    5 g" ^5 J/ H/ K4 m4 ]' E( I
        yhat2(i)=sum(yhat1(i:i+n-1))/n; 9 m: G/ ?7 g4 r8 v5 S8 H
    end
    ! d. `  u  ~4 M' Y, O2 Eyhat2   
    5 R. q' ^' i' v( H+ @- xplot(1:21,y,'*') $ ]  M* P6 q/ B
    a21=2*yhat1(end)-yhat2(end)
    5 D* I9 L0 D& w2 ib21=2*(yhat1(end)-yhat2(end))/(n-1)
    3 W$ S+ B' J; s4 v2 ]3 @. Fy1986=a21+b21
    9 F. `2 v# ~- S; t% r9 My1987=a21+2*b21
    - i" V$ `3 k8 O: J/ q  N) L/ ]$ }+ t! d: j
    + S3 `6 O1 k6 a# X

    ! `' t' N. N6 ]% ~  D趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。2 }0 y4 k: U; C1 ?/ E5 B

    ' P% Z& M% Y, O3 v6 ?# D1 a1 S4 r) D& h

      g2 J# [1 M8 |! E+ F% W* I————————————————1 G$ w  I" R, K6 W
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。3 Z4 s- e! Q& ]+ l0 l- z
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89440426
    1 b. I6 q3 ?* P  b
    * o6 r) E* O8 n3 [+ ^. i: e* ~4 ~! r, F5 x8 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-4-12 01:20 , Processed in 0.435156 second(s), 51 queries .

    回顶部