QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3307|回复: 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 |邮箱已经成功绑定
    移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。
    6 m7 m2 y6 @# ?9 G* d9 G3 w! ]. Y$ E6 r: X- \
    移动平均法8 ]- B( R+ S/ d, n( M
    移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。  移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。
    5 O& z; k0 L- `
    ) Q# N0 ?! i, M" V( b7 G: j$ |8 C简单移动平均法+ O8 k# j% L' E7 L% \

    % v. z# m% X6 g" j1 m' ^2 u* W1 {$ t- F; F- I0 x: [* e
    8 K% E7 v$ K5 L. a" o- ^
    近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。 ( w# d. M9 Y: q0 ~- o
    ' I/ u, Y! D# f3 J$ @5 ^- _
    简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。   @; M/ `, r- S. O7 W$ F. O/ X

    * G, A' S  E6 k0 _: e例 1  某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。 $ l8 |4 J. j, [

    . v* o1 b8 C' h+ O# w2 e  J3 E$ g, [% H$ w6 Z( X
    8 U" ~6 s9 B. r8 [! O  b

    / `# M" J2 y  S* E/ W/ A+ r( O+ o( `) M7 `7 F% [6 f; F9 ?7 r
    计算的 Matlab 程序如下: " i) P" n4 C+ t1 r, n8 w
    8 Y4 J6 v3 Q. H0 K
    clc,clear
    ( L' x6 Y! [1 y3 v( A% _  Ly=[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);   
    " j; a, G+ Y) j- ]5 n. g6 l n=[4,5];   %n 为移动平均的项数 0 e6 L5 z$ e( W: \3 n  c3 h5 L
    for i=1:length(n)   
    + J* z# j% L: C* R4 _ %由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组    ' m) K* z9 w1 A: E" n
        for j=1:m-n(i)+1         8 l$ w: F+ D+ {/ U" B
            yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);     
    ' _" s3 m* K0 h7 I! O& ]/ Y- S6 z5 F) r    end    9 V, p2 w. `/ z, B
        y12(i)=yhat{i}(end);     + F- L$ S) g! _
        s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2)); & ~& s" H3 x* C% G
    end
    1 y% y! M0 @+ x! M, x- |- R  _y12,s
    % O! I9 ^6 z7 |, u2 H' V+ |- \$ Q/ Z5 R5 V" C( r: _
    加权移动平均法0 k9 a( |+ v  s% X" m0 s$ V$ U: y
    在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。 4 N9 o9 r4 W9 f
    0 j& j) }# o& V3 D
    2 A( M; S) w( s) t
    ! K: d' u1 \1 u$ [) s
    例 2  我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量
    # x: t5 \$ w( p& z0 L/ [
    / F9 C4 ^3 U- B  y$ G4 D5 Z  a: @5 t
    : O9 ]2 i2 \- X- @% L  ~& i* G1 |: _/ H3 x  t# K4 ]* ?) P

    6 Z5 y, f" q$ `+ ^3 O* F( P: ^; o# x2 [
    " V& c0 l2 Z. I8 E7 u9 ~8 j9 K3 {

    ' t+ E( r/ k$ v. y0 V/ _" n4 l0 w7 {, a( c$ O
    计算的 MATLAB 程序如下: ; `; @4 x% r; L) {

    $ x6 {, f6 W7 h4 ry=[6.35 6.20    6.22    6.66    7.15    7.89    8.72    8.94    9.28    9.8]; . r1 \2 w' i/ a2 h8 b, W2 P0 k
    w=[1/6;2/6;3/6];
    ( D  u  g# i' j" o$ y4 Am=length(y);n=3; + P$ t/ p1 k# h& f
    for i=1:m-n+1     
    % }/ Z& i1 W% T0 c8 E    yhat(i)=y(i:i+n-1)*w; ) a* ?% U6 Z; i7 y, {, M5 e" M
    end
    3 v+ k, F4 I) W* ]yhat
    - u" E3 H& n( r& O7 K. `  Verr=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m)
    : _' X" P, R5 y6 I3 F  ~" iT_err=1-sum(yhat(1:end-1))/sum(y(n+1:m)) - v' Y  w1 x* g2 h" }% |: x
    y1989=yhat(end)/(1-T_err)
    / w6 F/ p! t1 I
    1 ?; T! \; `$ b 在加权移动平均法中,   的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。
    + E. Y8 L* O! B& O/ F4 J  ~5 d8 @+ M1 {  r
    趋势移动平均法& ~6 S6 [2 h) |. j# m: t
    简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。  一次移动的平均数为
    9 K2 P, b2 y) o% `1 e: O& I
    9 J! ^3 x* f4 |/ ~* j" y' Z, Z& O7 _6 l
    " C- J4 w2 j; t- G$ o' W
    7 n" X0 K1 l- u3 {" F  f
    - M, A0 l' u6 \1 B

    ) e; `2 y8 R& @- |3 \( R3 J, Z& K5 k' D# B2 J  }& C) E- G/ L' p4 Z
    例 3  我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。
    ; v1 M. m4 n8 `; N+ c
    6 T( ?! r6 `( C7 ~: J9 z, _$ ?1 l8 V( K5 U3 x
    1 O1 v9 L! c2 n6 Z
    解  由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。 # Q; L7 O" w7 p; l

    1 s4 Q$ B( e6 J+ Z6 g" V! V9 L! p
    # ]. g- A. t  u7 i2 a! j
    $ u& J2 e. J2 ^0 \, i( C计算的 MATLAB 程序如下: 6 s% j) _, U! X7 X
    ( e9 r: T; F& r1 ~
    clc,clear 8 Z3 ^+ ?! Z( X; U" T& L) d
    load y.txt   %把原始数据保存在纯文本文件 y.txt 中
    # m2 A, T5 n1 g* T+ X! ^m1=length(y);    2 @8 P/ U: F+ U# E# M
    n=6;   %n 为移动平均的项数
    + ~& `: v/ ~% j% Ufor i=1:m1-n+1     
    - j+ o* k- Q* c$ j    yhat1(i)=sum(y(i:i+n-1))/n; 3 ~4 C. j. r8 H# C# u% d% M2 n
    end
    1 K5 B9 f& ?! D; S, ^; k. I: W+ w" Nyhat1
    ; C! b; ~  ?& B; vm2=length(yhat1);
    : |% e' S( w  P0 _) Jfor i=1:m2-n+1   
    6 {( M0 Q) q- K+ S2 Q# D    yhat2(i)=sum(yhat1(i:i+n-1))/n;
    - J; e$ |0 E. ]  p+ s' B; }end
    & j" R6 |4 N  |. J; cyhat2   8 |/ t9 C, r  I
    plot(1:21,y,'*') 9 B7 @! }' F# Y+ d4 y; }/ D
    a21=2*yhat1(end)-yhat2(end)
    $ x- d! Q  S# v+ p6 Hb21=2*(yhat1(end)-yhat2(end))/(n-1) ! V0 \" k. I9 N7 y" w4 d, P( m5 a
    y1986=a21+b21 1 Z5 o4 c1 G2 V+ q6 x
    y1987=a21+2*b21 . C* }) e5 M* ?8 \
    % b1 F! ^6 a$ g6 ~6 b3 y1 X

      }, G- M; z) I0 j1 M- [) W: n; F  x" g& |$ f# A# w& g
    趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。
    . u& N$ t  G6 ]; S4 L$ p1 n  }) a9 a* ^
    # z2 t, M7 K9 y8 H! u$ x# H  k1 T

    : [, y8 P$ M# e————————————————
    2 f  H6 L& n, [* {7 P2 Z* y$ h* k: {- S版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。/ J! x+ p" o7 U4 R
    原文链接:https://blog.csdn.net/qq_29831163/article/details/894404266 y! o; [8 @) u0 v

    . `- o4 t0 F' Q  f! j) v2 u- o
    " f$ k+ E* V4 r# n; w8 ?9 ^
    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-11 21:53 , Processed in 0.424972 second(s), 51 queries .

    回顶部