- 在线时间
- 791 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2017-6-12
- 听众数
- 15
- 收听数
- 0
- 能力
- 120 分
- 体力
- 36352 点
- 威望
- 11 点
- 阅读权限
- 255
- 积分
- 13866
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 616
- 主题
- 542
- 精华
- 12
- 分享
- 0
- 好友
- 225
TA的每日心情 | 开心 2020-11-14 17:15 |
|---|
签到天数: 74 天 [LV.6]常住居民II
 群组: 2019美赛冲刺课程 群组: 站长地区赛培训 群组: 2019考研数学 桃子老师 群组: 2018教师培训(呼伦贝 群组: 2019考研数学 站长系列 |
移动平均法 可以作为一种数据平滑的方式 ,以每天的气温数据为例,今天的天气可能与过去的十天的气温有线性关系;或者有的人对食物有一种节俭的美德,他们做的饭菜能看出有些是上一顿的,当然也有一部分是今天的做的,再假设隔两顿的都被倒掉了,并且每天都是这样的,那么这碗饭菜可能就是一部分上一顿的再加上一部分今天现做的,这就是一个一阶的移动平均。1 H$ u# m b% ?1 K# w9 J# \' g- L
- g9 k9 ]( `9 z" x. y2 @移动平均法1 P2 q2 z6 t& B% h. I4 M
移动平均法是根据时间序列资料逐渐推移,依次计算包含一定项数的时序平均数, 以反映长期趋势的方法。当时间序列的数值由于受周期变动和不规则变动的影响,起伏 较大,不易显示出发展趋势时,可用移动平均法,消除这些因素的影响,分析、预测序列的长期趋势。 移动平均法有简单移动平均法,加权移动平均法,趋势移动平均法等。
. l, \3 B. ~) j S& ]7 j2 J/ V9 K5 ]6 A9 R" H7 Y% o+ A$ L
简单移动平均法6 x/ o: t+ H o/ s- S& {: q
$ I( c! U5 S; c! {
![]()
~7 z; d8 k: b- @* c; S: J# P I7 W6 L, |
近N 期序列值的平均值作为未来各期的预测结果。一般 N 的取值范围: 5≤N≤ 200。当历史序列的基本趋势变化不大且序列中随机变动成分较多时,N 的 取值应较大一些。否则 N 的取值应小一些。在有确定的季节变动周期的资料中,移动平均的项数应取周期长度。选择佳 N 值的一个有效方法是,比较若干模型的预测误 差。预测标准误差小者为好。 - _2 Q; O* A7 x* O; H, N& f F6 a
0 m& i3 Q7 w4 }% N
简单移动平均法只适合做近期预测,而且是预测目标的发展趋势变化不大的情况。 如果目标的发展趋势存在其它的变化,采用简单移动平均法就会产生较大的预测偏差和滞后。
+ H& P: h, U3 R5 w. ~: U5 V( k, ]
例 1 某企业 1 月~11 月份的销售收入时间序列如表 1 示。试用一次简单滑动平 均法预测第 12 月份的销售收入。
r6 K/ O; Z) Y b6 g$ T C
5 Y7 g: F. P) O% ~, x2 e+ b& u- H4 k![]()
E! B0 f: `7 X8 p/ R t4 F* ~
" u* T. u" f' s1 V. |' p7 X# } ' W# N7 ?1 t H) I3 ~
3 _, h% g; E: `
计算的 Matlab 程序如下:
( ~! c4 v- p' ?0 E( `
j: v% E# @4 T( Iclc,clear 7 h6 u+ S$ z# [2 W8 K0 `3 h
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); / V/ s9 I5 g) \+ p- d0 K7 a! B- v7 X
n=[4,5]; %n 为移动平均的项数
& |% M8 W, u" `% {for i=1:length(n) 1 {7 ~7 a# `/ n
%由于 n 的取值不同,yhat 的长度不一致,下面使用了细胞数组
% l L) k3 N' X, u- i( q for j=1:m-n(i)+1
; l/ @, o& N0 T yhat{i}(j)=sum(y(j:j+n(i)-1))/n(i);
5 O4 G6 B. ^2 B) |% W end
! g8 {( [) q3 O3 B; q y12(i)=yhat{i}(end);
, m/ P, H0 p( s2 q$ u' V' E# h s(i)=sqrt(mean((y(n(i)+1:m)-yhat{i}(1:end-1)).^2));
, [" G" b8 S* a& ^* |end " a6 c3 {8 z6 B' C9 z. p% B
y12,s 5 a( U( B% S2 [3 _
! ^. i; X/ Y. j9 U$ i4 f4 r% i加权移动平均法' Y4 q; ?/ m1 B4 o
在简单移动平均公式中,每期数据在求平均时的作用是等同的。但是,每期数据所包含的信息量不一样,近期数据包含着更多关于未来情况的信心。因此,把各期数据等同看待是不尽合理的,应考虑各期数据的重要性,对近期数据给予较大的权重,这就 是加权移动平均法的基本思想。 & q& }% i8 w _1 T9 `. f6 S
# K c9 B( _9 d9 C6 R7 C5 v3 H. o
3 a0 N* O- [7 I6 W7 z
, x. e3 g4 O7 Q7 v+ Y2 p( L* {
例 2 我国 1979~1988 年原煤产量如表 2 所示,试用加权移动平均法预测 1989 年 的产量! N; v: j" j# }1 v
0 ~8 W2 H6 H' p0 W+ U
( N" J4 J$ ?9 t8 D }
! a1 ]/ m% [. b/ h![]()
+ F! D! { F. n- f
. b0 T5 k* v& \2 T: ?9 W! f! L ( A5 b( X2 @7 r' N* [2 Z1 n. A
4 n, f6 w. R8 f3 W, Y9 A8 h
' X7 u7 X9 h6 ]: e3 E计算的 MATLAB 程序如下:
, K# U4 h; D6 c$ w" J- p9 Y
- u" O$ a3 p ~. _) G ?8 ^7 hy=[6.35 6.20 6.22 6.66 7.15 7.89 8.72 8.94 9.28 9.8]; * O7 h" z$ `' Y( P6 B; T& |, \
w=[1/6;2/6;3/6];
5 `1 i1 i! s" Hm=length(y);n=3; 5 G! R3 ] x1 [& R
for i=1:m-n+1 : M5 `! w; B5 j) T
yhat(i)=y(i:i+n-1)*w; 8 Q( E% Z& F" n6 {4 q' m
end
& W9 T* o! x- t: |* b% ?, k; ~; \yhat
+ G A; u2 u) xerr=abs(y(n+1:m)-yhat(1:end-1))./y(n+1:m) " p7 M6 B: k# w' w8 K
T_err=1-sum(yhat(1:end-1))/sum(y(n+1:m)) 1 h. ]: U# U. F$ |$ G2 z
y1989=yhat(end)/(1-T_err)4 P1 l" z$ K/ t
' |# q: n. l* G6 a! ^ r
在加权移动平均法中, 的选择,同样具有一定的经验性。一般的原则是:近期 数据的权数大,远期数据的权数小。至于大到什么程度和小到什么程度,则需要按照预 测者对序列的了解和分析来确定。 1 W5 l2 l: |( s/ j- i% N
$ {+ J Y. U! M' O7 J" h趋势移动平均法/ T1 [9 c4 r/ x, u
简单移动平均法和加权移动平均法,在时间序列没有明显的趋势变动时,能够准确 反映实际情况。但当时间序列出现直线增加或减少的变动趋势时,用简单移动平均法和 加权移动平均法来预测就会出现滞后偏差。因此,需要进行修正,修正的方法是作二次 移动平均,利用移动平均滞后偏差的规律来建立直线趋势的预测模型。这就是趋势移动平均法。 一次移动的平均数为
+ w' u$ _- f/ c* ]! p# L6 x% o7 ~+ d' _% [$ D
9 Q; e8 e B! V# p( d* h) u# x
9 y# x2 B1 N; N" P, t. `
![]()
! r2 r% Q6 U+ m( {; i: G/ t: M6 o. y9 k1 K) W1 ?; z. D
2 K3 v9 S& ^% a* P* Q9 U
5 h/ m( l- c5 x8 r& i2 i
例 3 我国 1965~1985 年的发电总量如表 3 所示,试预测 1986 年和 1987 年的发 电总量。
( m4 V* c' q& Q! d+ `* F1 N; P/ {: S9 a2 x, o5 }! k) l3 f) t
![]()
8 i& H6 G' X9 l" w$ j( j: w# W. Q* c6 {8 W- {: I/ E
解 由散点图 1 可以看出,发电总量基本呈直线上升趋势,可用趋势移动平均法 来预测。 $ r8 g1 Z6 L: W# C* u- k" w
; P3 q1 r, R* z' z , k7 `1 {5 [5 |3 C* c
) V5 ?: \, V3 B7 d" Q! f0 V- x计算的 MATLAB 程序如下: + j7 T% ~% L5 N) ?
% i7 o+ Y: L; G
clc,clear
9 t3 f2 k7 K8 o- K/ Qload y.txt %把原始数据保存在纯文本文件 y.txt 中 4 Y' L- P+ Q/ f
m1=length(y);
6 T( P* E: k% P$ Z% Mn=6; %n 为移动平均的项数 1 ?1 b' ~2 j) a9 M8 n3 X
for i=1:m1-n+1
# R8 M- |& @# e3 a yhat1(i)=sum(y(i:i+n-1))/n; 9 k [0 Q& O' I9 g E" V
end
+ _! E' c# E% R( j! g; D% p# A! lyhat1 & g( h, K! U3 g, r6 _5 t
m2=length(yhat1); ( Y; M, D- V6 c1 c( N; q: H6 {
for i=1:m2-n+1 . H! |% r( r& R# w( ~
yhat2(i)=sum(yhat1(i:i+n-1))/n;
5 o5 V, L3 n8 [% r& [end
3 h) |4 G& t- Q( eyhat2
5 e% S. V4 b, Y" G @# t# @plot(1:21,y,'*')
9 x5 c1 d7 f) {: Y! \" Pa21=2*yhat1(end)-yhat2(end)
' @& q: v9 ]" G& f1 ~. vb21=2*(yhat1(end)-yhat2(end))/(n-1)
* v4 X0 W7 m" o( M$ Iy1986=a21+b21
+ a' { h. Q$ Z: V: Hy1987=a21+2*b21
6 k7 P" |9 {2 |/ \, f. g* x
% v/ S* w4 a% v& o4 E' o, b/ o u% l* O$ y! Z7 | c) a
7 Q+ {: c0 f; C9 H3 \
趋势移动平均法对于同时存在直线趋势与周期波动的序列,是一种既能反映趋势变 化,又可以有效地分离出来周期变动的方法。* o! A+ a- i/ K) M2 W/ `
5 K0 T+ E. u2 L8 S; G
) E* k! E9 f9 T" i" |: g) C8 { U+ g5 e1 D
————————————————
. O) `5 S N& ~0 |6 x: U版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
/ [, v* D1 w) I6 V! e" x ^+ i原文链接:https://blog.csdn.net/qq_29831163/article/details/89440426
5 G' m; S, U k2 `
# c5 e/ @% M1 f2 [
' B! X7 g# w8 _' K |
zan
|