补充5 供应链中的需求预测(一)时间序列预测法

2023-10-09 08:40

本文主要是介绍补充5 供应链中的需求预测(一)时间序列预测法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        供应链的需求预测方法多样,正如上一篇文章提出的。预测方法分为两部分部分讲,时间序列预测法、基于java的时序预测算法实现及机器学习在预测中的应用。本文为第一部分,介绍时间序列预测法。本文只介绍了几种供应链中常用到的时间序列预测方法,更多预测方法可见金融时间序列分析讲义,讲义虽以金融数据作为讲解,但是预测方法大同小异。

目录

一、静态预测法

 1.估计需求水平和需求趋势

 2.估计季节性因素

 二、适应性预测法

1.移动平均法

2.简单指数平滑法

3.趋势调整的指数平滑法(Holt模型)

4.趋势和季节调整的指数平滑法(Winter模型)

 三、预测误差的度量


一、静态预测法

        静态预测法假定,对于系统成分中的需求水平、需求趋势和季节性因素的估计不随观察到的新需求而改变。在这种情况下,利用历史数据来对每一个参数进行估计,然后将估计出的参数值应用于所有的未来预测中。假定需求的系统成分为混合型,也就是说:

系统成分=(需求水平+需求趋势)*季节性因素

        在这里先给出一些基本定义:

        在静态预测法中,在第t期对第t+l期的需求进行预测的计算公式如下:

         下面以MoonLight公司的不锈钢为例,进行预测。该公司过去三年的需求数据如下:

   1.估计需求水平和需求趋势

        首先,需要提出需求数据中的季节性因素。剔除季节性因素的需求(deseason-alized demand) 是指在没有季节性波动的情况下被观察到的需求。时期p(periodicity)是指每次季节性循环包含的期数。在这里p=4。

        第t期剔除季节性因素后的需求\bar{_{Dt}}可用下面的公式求得:

   

         下面就是上面公司剔除季节性因素后的需求:

        基于需求随时间的变化,剔除季节性因素后的需求 \bar{_{Dt}}与时间t质检存在以下线性关系

        上述的数据,得到的线性关系如下: 

 2.估计季节性因素

        第t期的季节性因素\bar{_{St}}是实际需求Dt和剔除季节性因素后的需求\bar{_{Dt}}的比值,如下所示:

        上面的数据的得到的结果如下所示:         

         若在数据中有r个季节性循环,对所有表示形式pt+i(1<=i<=p)的时期,可以计算季节性因素如下:

        在这里r=3,季节性因素计算如下: 

        利用静态预测法计算未来4个季度的预测值如下: 

 二、适应性预测法

        在适应性预测中,需求水平、需求趋势和季节性因素的估计值在每次观察到实际需求后都要进行修正。适应性预测法的优点在于估计值中将所有观察到的新数据都考虑其中了。

        首先,先定义下面一些符号:

         在适应性预测法中,利用第t期的需求水平估计值和需求趋势估计值,在第t期对第t+l期进行预测。预测公式如下:

         适应性需求预测框架四个步骤如下:①计算初始值②预测③估计误差④修正估计值

        在预测过程中,选取哪种方法最为合适取决于需求的特性和需求系统成分的组成。在每种情况下,都假定待预测的时期为t。

1.移动平均法

        当需求中没有明显的趋势或季节性因素时,可以用移动平均法进行预测。在这种情况下:

系统的系统成分=需求水平

        在移动平均法中,将最近N个时期需求的平均值作为第t期需求水平的估计值,也就是N期移动平均,具体计算方法如下:

         当前对未来所有时期的预测都是一样,都是基于当前对需求水平的估计。预测公式如下:

         在观察到第t+1期的实际需求后,我们对估计值进行如下修正:

         要计算新的移动平均值,只要加入最新观察值并舍弃最早的观测数据就可以了。修正后的移动平均值则用于对下一期的预测。在进行预测时,移动平均法赋予最近N个时期的数据同样的权重,同时忽略那些较早的数据。当增加移动平均的期数N时,移动平均值对最近观察到的需求响应度会降低。

2.简单指数平滑法

        当需求没有明显的、可观察到的趋势或季节性因素时,采用简单指数平滑法比较合适。在这种情况下:

需求的系统成分=需求水平

        由于假设需求没有明显的趋势或季节性,所以需求水平L0的初始估计值可以用所有数据的平均值来估计。给定从第1期到第n期的需求数据,可以得到:

         在第t期对所有未来时期的预测值等于当前的需求水平估计值,可表示如下:

       上式α(0<α<1)为需求水平的平滑系数。修正后的需求水平时观察到的第t+1期的需求(Dt+1)和第t期原来的需求水平估计值(Lt)的加权平均。上式也可改写为

         需求水平的当前估计值时所有历史需求的加权平均,其中近期观察值的权重大,元气观察值的权重小。α取值越大,预测对近期观察值的响应性越好;相反,α取值越小,预测的稳定性越好,但对近期观察值的响应性越差。

3.趋势调整的指数平滑法(Holt模型)

        趋势调整的指数平滑法(Holt模型)适用于需求的系统成分仅包括需求水平和需求趋势,而不存在季节性因素的情况。在这种情况下:

需求的系统成分=需求水平+需求趋势

        通过对需求Dt和时间进行线性回归,可得到需求水平和需求趋势的初始估计值,如下式所示:

         在这种情况下,由于已经假定需求有趋势成分,但不存在季节性因素,所以对需求和时间进行线性回归是合适的。

        在第t期,给定需求水平估计值Lt和需求趋势估计值Tt,那么未来时期的预测值可表示如下:

         在观察到第t期的实际需求后,对需求水平和需求趋势的估计值进行如下修正:

   上式α(0<α<1)为需求水平的平滑系数,β(0<β<1)为需求趋势的平滑系数。可以看到,不管是需求水平修正还是需求趋势修正修正后估计值都是实际观察值与原来的估计值的加权平均。

4.趋势和季节调整的指数平滑法(Winter模型)

        Winter模型适用于需求的系统成分中包括需求水平、需求趋势和季节性因素的情况。在这种情况下:

需求的系统成分=(需求水平+需求趋势)*季节性因素

        在第t期,给定需求水平为Lt、需求趋势为Tt和季节性因素为St,...,St+p-1,那么对未来时期的预测可表示为:

         观察到第t+1期的需求后,对需求水平、需求趋势和季节性因素的估计值进行修正:

  上式α(0<α<1)为需求水平的平滑系数,β(0<β<1)为需求趋势的平滑系数;γ(0<γ<1)为季节性因素的平滑系数。可以看到,不管是需求水平修正还是需求趋势、季节性因素修正后估计值都是实际观察值与原来的估计值的加权平均。

 三、预测误差的度量

        基于下面两个原因,管理者必须对预测误差进行仔细分析。

        ①管理者可以利用误差分析来判定线性的预测方法是否可以准确预测需求的系统成分。

        ②所有应急计划都必须考虑预测误差。

        只要观察到的误差的历史误差估计范围内,就可以继续使用现行的方法。如果持续超出,就需要及时改变预测方法了。

        第t期的预测误差Et为:

         平均平法误差(MSE)是度量预测误差的常用指标,具体公式如下:

         MSE与预测误差的方差有关,对大误差的惩罚更大。所以,如果较大预测误差引发的成本远大于精确预测带来的收益,则非常适合用MSE这一指标来预测方法进行比较。当预测误差以0为重心对称分布时,也适合用MSE来衡量预测误差。

        平均绝对偏差(MAD)定义为整个预测期内所有时期的绝对偏差的平均值,表达式为:

         如果需求的随机成分呈正态分布,那么可用MAD来估计随机成分的标准差,即

σ=1.25MAD

        因此,估计需求的随即成分的均值为0,标准差为σ。在预测误差不是对称分布时,MAD是比MSE更好的误差度量指标。即使是在预测误差对称分布的情况下,如果预测误差的成本和误差的大小成正比,也可以用MAD来选择预测方法。

        平均绝对百分比误差(MAPE)是指绝对偏差站需求的百分比的平均值,计算公式如下:

         当潜在需求具有较强季节性且各期需求变化较大时,MAPE是一个很好的度量预测误差的指标。

        当一种预测方法已不能反应潜在需求模式时(如发生经济危机时),预测误差不可能以0为中心随机分布。通常,需要一种跟踪和控制预测方法的手段。其中一种手段就是用预测误差的滚动和来评估偏差(bias),公式如下:

         跟踪信号(TS)是偏差与平均绝对偏差的比值,即

         如果任一时期的TS超出±6的范围外,就说明预测出现了偏差,可能低估了需求(TS<-6)或高估了需求(TS>6)了。之所以出现这种情况,可能是因为预测方法存在缺陷或潜在的需求模式发生了变化。

        当需求突然减少(如发生经济危机时)或急剧增加是的历史数据丧失相关性时,TS也可能增大。如果需求突然减少,那么在进行预测时就要增大当前数据的权重,提高预测的响应性。麦克莱恩建议,在使用指数平滑法进行预测时采用“α值递减”的方法,公式如下:

         长期来看,平滑系数收敛于α=1-β,随着时间的推移,预测值变得更加稳定。

这篇关于补充5 供应链中的需求预测(一)时间序列预测法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/171659

相关文章

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

Java将时间戳转换为Date对象的方法小结

《Java将时间戳转换为Date对象的方法小结》在Java编程中,处理日期和时间是一个常见需求,特别是在处理网络通信或者数据库操作时,本文主要为大家整理了Java中将时间戳转换为Date对象的方法... 目录1. 理解时间戳2. Date 类的构造函数3. 转换示例4. 处理可能的异常5. 考虑时区问题6.

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

uva 10131 最长子序列

题意: 给大象的体重和智商,求体重按从大到小,智商从高到低的最长子序列,并输出路径。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vect

POJ1631最长单调递增子序列

最长单调递增子序列 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.math.BigInteger;import java.util.StringTokenizer;publ

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06