基于灰色神经网络的订单需求预测Matlab代码

这篇具有很好参考价值的文章主要介绍了基于灰色神经网络的订单需求预测Matlab代码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.案例背景

1.1 灰色理论

        灰色系统理论是一种研究少数据、贫信息,不确定性问题的新方法,它以部分信息已知、部分信息未知的“小样本”、“贫信息"不确定系统为研究对象,通过对“部分”已知信息的生成、开发,提取有价值的信息,实现对系统运行行为、演化规律的正确描述和有效监控。
        灰色理论是我国学者邓聚龙教授在1982年首先提出的,该理论认为任何随机过程都可看做是在一定时空区域内变化的灰色过程,随机量可看成灰色量,同时,他认为通过生成变换可将系统数据无规律的序列变成有规律的序列。灰色理论强调通过对无规律的系统已知信息的研究,提炼和挖掘有价值的信息,进而用已知信息去揭示未知信息,使系统不断“白化”。
        灰色系统中建立的模型称为灰色模型(grey model,GM),该模型是以原始数据序列为基础建立的微分方程。灰色建模中最有代表性的模型是针对时间序列的GM建模。它直接将时间序列数据转化为微分方程,利用系统信息,使抽象的模型量化,进而在缺乏系统特性知识的情况下预测系统输出。

        GM模型首先对原始数据序列做一次累加,使累加后的数据呈现一定规律,然后用典型曲线拟合该曲线。设有时间数据序列X(0):

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

1.2 灰色神经网络

        灰色问题是指对灰色的不确定系统行为特征值的发展变化进行预测的问题,该不确定系

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

        将变换后的式(37-8)映射到一个扩展的BP神经网络中就得到n个输人参数、1个输出参数的灰色神经网络,网络拓扑结构如图37-1所示。

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

1.3 冰箱订单预测

        对于冰箱市场来说,影响其需求量的因素很多,比如季节性因素、成本、产品质量水平、品牌认可,售后服务、产品结构,产品生命周期、价格波动及销售力度、竞争对手,市场特征、性能价格比等,根据各因素对订单需求影响的大小,从中选取需求趋势、产品的市场份额、销售价格波动、订单缺货情况和分销商的联合预测情况5个因素作为主要因素预测冰箱订单量。
        产品的市场份额是指某个企业销售额在同一市场(或行业)全部销售额中所占比重。一般来说,某市场中,企业越多,单个企业所占比重越低,即市场份额小,该市场的竞争程度越高。
        产品的生命周期是指产品从推出市场到从市场退出的周期。产品订单同产品生命周期有很大关系,比如产品处于成长期,那么其需求将增长快速。处于成熟期,其需求的增长比较缓慢且稳定。
        价格波动一般指企业为了增加产品的销量,减少闲置库存,提升品牌竞争力,又或者由于原材料的成本增加﹐为满足一定的盈利,短期时间内价格的变化。价格的波动导致的需求量突增或突减可反映在市场活动如促销前后,直接的价格战前后,因而在做需求预测时要考虑预测期间的市场活动状况,对预测的需求量按促销等力度加以调整。
        订单满足率是指由于供应量的不足导致的缺货和其他原因不能满足给定数量的货物所占总订单数的比例。对于某冰箱公司,一般情况下,下游企业或者说批发商会在给定前置期的范围内下订单,但是由于月前的以需求计划为引导的生产计划可能不能满足足够数额的需求,所以会产生制造商和批发商之间的短期博弈。
        分销商联合预测因素是指供应商、制造商,配送商、分销商,零售商直至最后的客户连接成一个有机体,考虑各自上下游之间的需求匹配性,进行联合预测,实现信息共享,来减少供应链中的存货、生产及运输成本,快速响应消费者需求,提高订单满足率和客户服务水平。

2.模型建立

        基于灰色神经网络的冰箱订单预测算法流程如图37-2所示。其中,灰色神经网络构建根据输人/输出数据维数确定灰色神经网络结构。由于本案例输入数据为5维,输出为1维,所以灰色神经网络结构为1—1—6—1,即LA层有1个节点,输人为时间序列t,LB层有1个节点,LC层有6个节点,第2~6个分别输人市场份额、需求趋势、价格波动、订单满足率、分销商联合预测5个因素的归一化数据,输出为预测订单量。

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

        灰色神经网络训练用训练数据训练灰色神经网络,使网络具有订单预测能力。灰色神经网络预测用网络预测订单数量,并根据预测误差判断网络性能。共有过去3年(36个月)的数据,首先取前30个月的数据作为训练数据训练网络,网络共学习进化100次,然后用剩余6组数据评价网络的预测性能。

3.编程实现

        根据灰色神经网络原理,在MATLAB中编程实现基于灰色神经网络的订单需求预测。

%% 该代码为基于灰色神经网络的预测算法

%% 清空环境变量
clc
clear

load data

%% 数据累加作为网络输入
[n,m]=size(X);
for i=1:n
    y(i,1)=sum(X(1:i,1));
    y(i,2)=sum(X(1:i,2));
    y(i,3)=sum(X(1:i,3));
    y(i,4)=sum(X(1:i,4));
    y(i,5)=sum(X(1:i,5));
    y(i,6)=sum(X(1:i,6));
end

%% 网络参数初始化
a=0.3+rand(1)/4;
b1=0.3+rand(1)/4;
b2=0.3+rand(1)/4;
b3=0.3+rand(1)/4;
b4=0.3+rand(1)/4;
b5=0.3+rand(1)/4;

%% 学习速率初始化
u1=0.0015;
u2=0.0015;
u3=0.0015;
u4=0.0015;
u5=0.0015;

%% 权值阀值初始化
t=1;
w11=a;
w21=-y(1,1);
w22=2*b1/a;
w23=2*b2/a;
w24=2*b3/a;
w25=2*b4/a;
w26=2*b5/a;
w31=1+exp(-a*t);
w32=1+exp(-a*t);
w33=1+exp(-a*t);
w34=1+exp(-a*t);
w35=1+exp(-a*t);
w36=1+exp(-a*t);
theta=(1+exp(-a*t))*(b1*y(1,2)/a+b2*y(1,3)/a+b3*y(1,4)/a+b4*y(1,5)/a+b5*y(1,6)/a-y(1,1));

kk=1;

%% 循环迭代
for j=1:10
%循环迭代
E(j)=0;
for i=1:30
    
    %% 网络输出计算
    t=i;
    LB_b=1/(1+exp(-w11*t));   %LB层输出
    LC_c1=LB_b*w21;           %LC层输出
    LC_c2=y(i,2)*LB_b*w22;    %LC层输出
    LC_c3=y(i,3)*LB_b*w23;    %LC层输出
    LC_c4=y(i,4)*LB_b*w24;    %LC层输出
    LC_c5=y(i,5)*LB_b*w25;    %LC层输出
    LC_c6=y(i,6)*LB_b*w26;    %LC层输出 
    LD_d=w31*LC_c1+w32*LC_c2+w33*LC_c3+w34*LC_c4+w35*LC_c5+w36*LC_c6;    %LD层输出
    theta=(1+exp(-w11*t))*(w22*y(i,2)/2+w23*y(i,3)/2+w24*y(i,4)/2+w25*y(i,5)/2+w26*y(i,6)/2-y(1,1));   %阀值
    ym=LD_d-theta;   %网络输出值
    yc(i)=ym;
    
    %% 权值修正
    error=ym-y(i,1);      %计算误差
    E(j)=E(j)+abs(error);    %误差求和       
    error1=error*(1+exp(-w11*t));     %计算误差
    error2=error*(1+exp(-w11*t));     %计算误差
    error3=error*(1+exp(-w11*t));
    error4=error*(1+exp(-w11*t));
    error5=error*(1+exp(-w11*t));
    error6=error*(1+exp(-w11*t));
    error7=(1/(1+exp(-w11*t)))*(1-1/(1+exp(-w11*t)))*(w21*error1+w22*error2+w23*error3+w24*error4+w25*error5+w26*error6);
    
    %修改权值
    w22=w22-u1*error2*LB_b;
    w23=w23-u2*error3*LB_b;
    w24=w24-u3*error4*LB_b;
    w25=w25-u4*error5*LB_b;
    w26=w26-u5*error6*LB_b;
    w11=w11+a*t*error7;
end
end  

%画误差随进化次数变化趋势
figure(1)
plot(E)
title('训练误差','fontsize',12);
xlabel('进化次数','fontsize',12);
ylabel('误差','fontsize',12);
%print -dtiff -r600 28-3

%根据训出的灰色神经网络进行预测
for i=31:36
    t=i;
    LB_b=1/(1+exp(-w11*t));   %LB层输出
    LC_c1=LB_b*w21;           %LC层输出
    LC_c2=y(i,2)*LB_b*w22;    %LC层输出
    LC_c3=y(i,3)*LB_b*w23;    %LC层输出
    LC_c4=y(i,4)*LB_b*w24;    %LC层输出
    LC_c5=y(i,5)*LB_b*w25;
    LC_c6=y(i,6)*LB_b*w26;
    LD_d=w31*LC_c1+w32*LC_c2+w33*LC_c3+w34*LC_c4+w35*LC_c5+w36*LC_c6;    %LD层输出
    theta=(1+exp(-w11*t))*(w22*y(i,2)/2+w23*y(i,3)/2+w24*y(i,4)/2+w25*y(i,5)/2+w26*y(i,6)/2-y(1,1));   %阀值
    ym=LD_d-theta;   %网络输出值
    yc(i)=ym;
end
yc=yc*100000;
y(:,1)=y(:,1)*10000;

%计算预测的每月需求量
for j=36:-1:2
    ys(j)=(yc(j)-yc(j-1))/10;
end

figure(2)
plot(ys(31:36),'-*');
hold on
plot(X(31:36,1)*10000,'r:o');
legend('灰色神经网络','实际订单数')
title('灰色系统预测','fontsize',12)
xlabel('月份','fontsize',12)
ylabel('销量','fontsize',12)

        运行结果如下:

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

基于灰色神经网络的订单需求预测Matlab代码,matlab机器学习-神经网络入门,matlab,人工智能,开发语言

        从图可以看出,灰色神经网络收敛速度很快,但是网络很快陷人局部最优,无法进一步修正参数。用训练好的灰色神经网络预测冰箱订单,灰色神经网络预测的平均误差为7.20%,说明灰色神经比较适用于小样本预测问题。

4.完整数据文件

        下载链接:

【免费】基于灰色神经网络的订单需求预测Matlab代码文章来源地址https://www.toymoban.com/news/detail-680733.html

到了这里,关于基于灰色神经网络的订单需求预测Matlab代码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于BP神经网络的火焰识别,基于BP神经网络的火灾识别

    背影 BP神经网络的原理 BP神经网络的定义 BP神经网络的基本结构 BP神经网络的神经元 BP神经网络的激活函数, BP神经网络的传递函数 代码链接:基于BP神经网络的火焰识别,基于BP神经网络的火灾识别资源-CSDN文库 https://download.csdn.net/download/abc991835105/88215777 神经网络参数 基于

    2024年02月11日
    浏览(44)
  • 基于Transformer(卷积神经网络、循环神经网络)的情感分类研究

    Requirements: * Python: 3.8.5 * PyTorch: 1.8.0 * Transformers: 4.9.0 * NLTK: 3.5 * LTP: 4.0  Model: Attention:   论文解读参考:   https://blog.csdn.net/Magical_Bubble/article/details/89083225 实验步骤: 1)下载VSstudio2019 注意:安装时勾选“Python开发”和“C++桌面开发” 2) 下载和安装nvidia显卡驱动 下载之后

    2024年02月07日
    浏览(47)
  • 基于 Python中的深度学习:神经网络与卷积神经网络

    当下,深度学习已经成为人工智能研究和应用领域的关键技术之一。作为一个开源的高级编程语言,Python提供了丰富的工具和库,为深度学习的研究和开发提供了便利。本文将深入探究Python中的深度学习,重点聚焦于神经网络与卷积神经网络的原理和应用。 深度学习是机器学

    2024年02月07日
    浏览(59)
  • 基于matlab的神经网络设计,matlab神经网络应用设计

    我来说下我的理解,不一定对,一起讨论下吧 1.100个字母,400个数字组成的训练样本应该是可以的,因为训练样本多的话会使整个网络的权值更加接近准确的权值,500个训练样本对于图像处理来说应该不算多。 2.因为预处理后的每个字母/图片为250的向量值,所有训练样本可以

    2024年02月06日
    浏览(44)
  • 基于双向长短期神经网络BILSTM的指数预测,基于gru神经网络的指数预测

    目录 背影 摘要 LSTM的基本定义 LSTM实现的步骤 BILSTM神经网络 基于双向长短期神经网络BILSTM的指数预测,基于gru神经网络的指数预测 完整代码:基于双向长短期神经网络BILSTM的指数预测,基于gru神经网络的指数预测(代码完整,数据齐全)资源-CSDN文库 https://download.csdn.net/d

    2024年04月24日
    浏览(62)
  • 【模糊神经网络】基于simulink的模糊神经网络控制器设计

    MATLAB2010b         由于模糊控制是建立在专家经验的基础之上的,但这有很大的局限性,而人工神经网络可以充分逼近任意复杂的时变非线性系统,采用并行分布处理方法,可学习和自适应不确定系统。利用神经网络可以帮助模糊控制器进行学习,模糊逻辑可以帮助神经网络

    2023年04月08日
    浏览(52)
  • 基于BP神经网络的风险等级预测,BP神经网络的详细原理,

    背影 BP神经网络的原理 BP神经网络的定义 BP神经网络的基本结构 BP神经网络的神经元 BP神经网络的激活函数, BP神经网络的传递函数 代码链接:基于BP神经网络的风险等级评价,基于BP神经网络的风险等级预测(代码完整,数据齐全)资源-CSDN文库 https://download.csdn.net/download

    2024年02月06日
    浏览(47)
  • 深度学习笔记之循环神经网络(十)基于循环神经网络模型的简单示例

    本节我们将前面介绍的几种 循环神经网络 —— RNN,LSTM,GRU text{RNN,LSTM,GRU} RNN,LSTM,GRU 关于实例中的一个演示,但重点并不仅在于这些模型,这里以 示例 的形式对 One-hot text{One-hot} One-hot 向量 重新进行认知 。 自然语言 ( Natural Language ) (text{Natural Language}) ( Natural Language ) 是人类

    2024年02月07日
    浏览(52)
  • 基于GUI的卷积神经网络和长短期神经网络的语音识别系统,卷积神经网的原理,长短期神经网络的原理

    背影 卷积神经网络CNN的原理 卷积神经网络CNN的定义 卷积神经网络CNN的神经元 卷积神经网络CNN的激活函数 卷积神经网络CNN的传递函数 长短期神经网络的原理 基于GUI的卷积神经网络和长短期神经网络的语音识别系统 代码下载链接:基于MATLABGUI编程的卷积神经网络和长短期神

    2024年02月12日
    浏览(38)
  • 小白的机器学习之路(四)神经网络的初步认识:基于pytorch搭建自己的神经网络

    当前交通大数据业务的需要,需要承担一部分算法工作(数据处理) 目标四: 学习深度学习基础:了解神经网络的基本结构、反向传播算法和激活函数等。 目标任务:使用深度学习算法构建一个简单的神经网络模型,并训练模型。 学习计划小贴士: 每天定期复习前几天的

    2024年02月15日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包