QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3360|回复: 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 |邮箱已经成功绑定
    移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。
    1 K1 y' X$ @$ L( @' K$ w1 C7 P- y. U( \( A+ P# a
    移动平均法
    ( i* R) s) V: @6 u9 t移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。  移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。 9 X7 j+ W. Y0 y# W/ H

    % S9 ^+ Y; F3 u' U简单移动平均法( [0 l3 d  w5 E* M

    ! X4 `! s/ [" i2 n' A
    ! [$ o/ g4 t: `5 D. _
    8 V2 w( Z+ ^* Z* @  V4 L近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。 2 p/ R" X7 d5 P9 x) v' _5 p7 C

    + y  T# e# _' l( ~! g1 R简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。 $ V+ }3 p' ^& n$ w, c6 a; Q

    / B& q0 H" \/ S. w! a! K例 1  某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。 / v( g7 [5 J! Z: V" p1 H# ~
    9 t* h9 ^7 ]( u) k
    - q5 P% }$ |( \/ y7 T' U" J: a

    & ~" }: U, S. t4 L$ m4 O. I% C  a/ P+ N+ [. ~

    ( n5 F( X3 v( p7 c+ S: u4 h! ?0 f计算的 Matlab 程序如下:
    $ Q$ ^6 i' ]/ `' q) P1 W4 T
    + `$ X3 C5 ^+ w- f  E8 L3 H9 qclc,clear
    $ u  u9 l# ~, I( [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);   ; s) Z% A- k5 e
    n=[4,5];   %n 为移动平均的项数
    / f( ]: F9 P$ w0 mfor i=1:length(n)    + Z9 @7 P/ a% K' t) N7 ^  g
    %由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组    9 Y# w- v3 Y) h
        for j=1:m-n(i)+1         
    6 a0 {& T. A7 {4 E" {+ C        yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);     
    , T+ n$ ]: v+ P1 T    end   
    - m1 G- N- D% \( i    y12(i)=yhat{i}(end);     ( A/ [, M& ~0 {7 I' }; B( |
        s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2)); + }; g5 q+ I' F# H
    end + i% p8 {. a1 ]+ y' c
    y12,s ! ?$ j% W# n- o; b% H

    # Y9 g: c+ a5 F2 n加权移动平均法; z) Z; L# j; i" @% Y4 c' Q
    在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。 5 x; H0 Q+ B  _# s8 R" X
    1 @& d6 o) |; k$ h2 F- @8 a

    , k) q' f- {  ?7 k3 w+ t' H$ x) a, h4 P9 [! ?" f5 Q: M
    例 2  我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量
    & @% |) l& H7 t! e; z8 t
    $ Z- ~7 D, X$ k. [% I! d
    0 w) m, g3 {$ S2 E- L7 ^4 S* G; N# J7 z1 {
    # L8 e' q% D0 Q( \% i$ C. |& K

    * R5 l+ i; ^3 p0 R  [' B: S5 ~. Y! ]0 u! Y8 ?
    2 N' T4 _, d; P, Y+ F
    4 B2 G' W5 k# B+ B3 J4 F# I3 H
    计算的 MATLAB 程序如下: ; I% g8 y2 U  m& {0 z9 x5 F7 ^4 \3 z

    ( H8 o" O+ n2 n  V  gy=[6.35 6.20    6.22    6.66    7.15    7.89    8.72    8.94    9.28    9.8]; $ ]! Z9 D9 y2 m; W
    w=[1/6;2/6;3/6]; # K, q0 e% n6 }3 L
    m=length(y);n=3; + d. Z2 ^2 a9 H9 S" L6 o; ?
    for i=1:m-n+1     7 A( l- Y# C) T2 L: ]
        yhat(i)=y(i:i+n-1)*w;   j, u' }% Z5 {; z8 M
    end # ]3 A, z- L3 ^& a5 x
    yhat
    1 V6 L6 \; [+ d3 Nerr=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m) $ _7 \, _( w9 X* ]1 c; [
    T_err=1-sum(yhat(1:end-1))/sum(y(n+1:m))
    + H" Y8 _$ m+ u" |y1989=yhat(end)/(1-T_err)
    + k! x, g& T3 j" y! }6 P# s% _) o/ K! t0 z5 B0 _% _& D! ]
    在加权移动平均法中,   的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。
    6 c5 e2 H) d! S1 s; c0 l. D( y# @+ p1 A* B* g  n
    趋势移动平均法
      F( f$ B( ?3 f简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。  一次移动的平均数为
    * C! P9 b: e, b  v2 D/ [, t* n% N" U* i3 \9 [0 N# j
    & g) v; G! V' f  H

    5 ?4 R/ ?- D& f$ e$ J7 v3 V' Z$ h$ u
    9 Z3 U# x0 v. e9 ~: U: _; J0 H2 O0 v4 ^" b

      E% W) Y7 h4 T9 o
    " s; d7 i  G! s! Q! S3 ?( b* D例 3  我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。 - ~. l' B3 ]. y" Q, A

    % d  p1 E& ?' [9 |7 C4 Z% y, f5 y4 q4 Q2 _# @

    + o) J: K2 l8 O# H解  由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。 0 J4 U: G7 B6 a  M
    : F6 r+ }5 D8 ~, Q, I: }* g" ]

    2 v* [2 C6 `0 r$ ?) N. H8 c# s' a* o
    计算的 MATLAB 程序如下: $ d( \: ]) w0 H4 X# q! K+ L
    9 ?" p0 I9 I% h
    clc,clear $ ~" g5 }8 F+ m7 ~4 [
    load y.txt   %把原始数据保存在纯文本文件 y.txt 中
    6 }2 k% z$ J# y3 u5 [& _m1=length(y);    , t* \* G# H5 p
    n=6;   %n 为移动平均的项数 2 Z/ U$ E8 ~) Q2 L" H7 Z
    for i=1:m1-n+1     
    $ [5 Z3 @$ g" w, O; `/ U. E    yhat1(i)=sum(y(i:i+n-1))/n;
    6 c& [. b0 h" u( D, v% f. Eend 1 U* R$ I! C9 I- J
    yhat1
    4 C  }7 B9 E' @% l8 m* M/ g2 ]m2=length(yhat1);
    + T& n  \. `; e* C) r$ Lfor i=1:m2-n+1    " }$ b: M* O7 z2 l7 S
        yhat2(i)=sum(yhat1(i:i+n-1))/n; / R. @+ F' h4 m  c/ p
    end 6 H( w+ }* N7 X" E2 j6 s# D% M7 t8 u. n
    yhat2   
    . ?" d0 K6 e2 x5 S! G9 O* m, w. qplot(1:21,y,'*') 4 o8 b) @" |. N8 o" l5 J2 {
    a21=2*yhat1(end)-yhat2(end)
    4 }8 r; m3 Z( f) Ab21=2*(yhat1(end)-yhat2(end))/(n-1) 7 Z" P5 d+ q! K& k0 V9 c
    y1986=a21+b21 $ D  a. m; O. J
    y1987=a21+2*b21 5 ^8 r. Q: ?' E4 b' D! r7 u0 R
    % [: s1 @8 h8 m7 ~* R
      X% R# a! H5 y/ m

    & m! r2 k  K3 r1 w5 k8 F( p$ S趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。
    . N* x+ B" z6 |5 S# @$ Q
    4 @  O8 ^, d( L) o: m6 x3 |
    & f2 d1 T  N9 S9 R) x2 J) @4 K
    + t- `7 A' o+ \$ O————————————————
    , x# e7 s. H$ P/ b版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。6 h# H7 i, p9 b& ^* y  W
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89440426
    . z4 s% E! P) v( {7 l- g+ t  N
    0 ^. h1 @8 {1 q, m6 c8 p% Q% [) u/ J' `7 x$ x
    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-12 01:57 , Processed in 0.421444 second(s), 50 queries .

    回顶部