问题提出

工业生产活动的目标是利用原料生产产品,从而产生利润。原料经过一系列加工过程,包括物理反应和化学反应,最终形成产品,生产的理想状态是原料到产品的转换率是确定的,工厂想生产多少产品就知道需要准备多少原料,提高生产效率。

许多工艺原理和生产经验都表明,在简化情况下,可以认为原料用量和产品产量之间近似是线性关系。这样,每一种原料和每一种产品之间都会有一个与原料用量无关的恒定转换率,在化工界称为收率

我们的目标是根据历史的原料量和产量计算出一个较准确的收率,然后在下一个生产周期(比如第二天)中根据原料用量预测产量,预测产量与实际产量越接近说明收率越准确。如下图:

反应在图上,目标就是使两条曲线尽可能重合。

怎么才能算出一个较准确的收率呢?

既然原料用量和产品产量之间近似是线性关系,而线性拟合又是非常成熟的技术,那么很容易想到,直接用历史数据进行线性拟合就可以解决问题了。

可是,现实情况并没有这么简单,由于数据的各种测量误差,直接使用线性拟合算法会得出非常荒唐的结果:

  1. 收率大于1,这意味着产品产量大于原料用量,凭空造出很多产品;

  2. 收率小于0,这更加离谱,原料越多反而产量越少。

这两种情况显然都违背了质量守恒定律,在现实场景中是不可能发生的,这样拟合出来的收率也没有任何用于预测的意义。

如此看来,原料和产品的拟合并不是完全无条件的,需要满足质量守恒定律,即所有产品产量小于原料用量且不会因原料增多而减少,这要求所有收率必须在[0,1]范围内。

质量守恒定律还要求任一种原料最终都转化成各种产品,不会有没有用掉的原料,也不会凭空产生产品,即各种产品对某一种原料的收率和等于1。

常规的线性拟合算法,只考虑拟合结果与目标最接近,并不考虑这些约束,所以当原始数据有误差时,拟合出荒唐的结果也就不奇怪了。

此外,工艺知识还提供了基础收率,它是个长期均值,直接用它预测“明天” 的产品产量效果很差,好比用年均气温去预测明天气温,显然无效,所以基础收率不能直接使用,只能作为参考,就像预测“明天”气温可以把年均气温作为参考一样,不能偏离特别远,否则即使拟合结果误差很小也不合适用于预测。

综上所述,约束条件有3个,分别是:

约束1:所有收率都在[0,1]范围内。

约束2:各种产品对某一种原料的收率和等于1。

约束3:不可以偏离基础收率太远。

我们的任务是研究如何在这些约束条件下利用原料和产品数据计算出较准确的收率,使其可以用于预测第二天的产量。

算法思路

利用历史数据,考虑用不同的数学方法来满足3个约束条件:

  1. 有边界的线性拟合法来满足约束1

我们可以把0和1作为边界,问题就转化成有边界的线性拟合,最优解一定会在边界或者是线性拟合结果处。把问题简单化以后就是我们中学时期解的二元一次函数在指定范围内的最大或最小值问题,如下图:

所幸实际生产中原料的种类不会特别多,穷举所有这些情况,最后找到误差最小的解即可满足收率范围在[0,1]内这一约束条件。

  1. 线性变换方法来满足约束2。

n种产品的收率和为1,意味着这些收率线性相关。有边界的拟合方法不能保证收率和不为1,可以将误差按权重线性分拆到各产品上修正收率,反复迭代即可满足收率和为1这一约束条件。如下图:

  1. 拟合偏差的方法来满足约束3。

今天的气温和明天差别不大,可以把今天和一年的平均气温之差作为计算明天气温的参考,如下图:

同理,实际生产中,收率同气温一样也是渐变的,即今天的收率和明天的收率差别不会很大,可以把今天的收率和基准收率得到的产品产量之差作为计算明天收率的参考,以此作为有边界拟合时的边界,保证结果收率不偏离基础收率太远。如下图:

这样得到的收率就可以同时满足三个约束条件,而且准确性也高于基础收率。

实践效果

把上面思路写成代码,就可以计算收率了。

A
1 [[30,8],[31,7],[38,10]]
2 [[2,13,23],[3,15,20],[11,13,24]]
3 [[0,0.5,0.5],[0.55,0.05,0.4]]
4 0.1
5 =mul(A1,A3)
6 =A2.(~--A5(#))
7 =bd(A1,A2,A3,A4).(~.(~.(round(~,3))))
8 =A6.~.((idx=#,bdfit(A1,A6.([~(idx)]),A7.(~(idx))).conj()))
9 =transpose(A8)
10 =func(A12,A9,A3)

SPL提供了很多矩阵计算方法,可以高效的进行矩阵运算,搭配其强大的集合运算能力,可以高效的实现上述算法思路。

计算结果示例:

原料X

产品Y

基础收率B

最终的收率W

下面是直接用最小二乘法拟合得到的收率W’

很显然,它的结果有的大于1,有的小于0,完全不满足约束条件,所以无法使用。

通过验证,W满足3个约束条件,为了进一步验证W的准确性,我们用它和基础收率B对比,以均方误差MSE作为评价标准,MSE越小,预测产品产量与实际产量差距越小,收率越准确。

先来看使用基础收率B,各出料的均方误差MSE

MSE1=12.24

MSE2=16.24

MSE3=8.98

其中MSEj是第j个出料的MSE

再看使用W,各出料的MSE

MSE1=10.97

MSE2=5.13

MSE3=3.86

很明显,拟合后的W效果更好。

最后说明一下,本文只介绍优化产品收率的思路,具体的计算过程并没有详细描述。文中的代码也是示意性的,因为有边界的线性拟合、计算边界范围、线性变换等都需要大量的运算,都展示出来只会使文章变的臃肿且晦涩难懂,如果有读者对细节过程感兴趣,可以和我们联系沟通。

开发这类算法常常需要做大量实验来选择合适的函数计算式并调整参数,SPL编程的高效性会发挥巨大的作用,在同样的时间内能够尝试更多种方案。

资料

  • SPL下载
  • SPL源代码

SPL工业智能:原料与产品的拟合相关推荐

  1. SPL 工业智能:识别指定工况

    问题提出 工业生产过程中会产生大量的数据,比如电压.温度.流量等等,不同的工况条件下,数据的走势不同,比如产量稳定时,流量走势平稳,产量增加时,流量势必也会增加,体现在图像上就是流量曲线上升. 比如下 ...

  2. SPL工业智能:发现时序数据的异常

    基本问题 工业生产过程中会产生大量的数据,比如电压.温度.流量等等,它们随时间推移而不断产生,这些数据在多数情况下是正常的,否则生产无法正常进行:少数情况下,数据是异常的,生产效率会降低甚至发生事故. ...

  3. 直击2020国际工业智能展览会,百超迪能携明星产品款款而来

    "2020IIE苏州国际工业智能展览会"经精心筹备,于2020年10月15日-17日在苏州国际博览中心隆重开幕,博览会展览面积达7万平米,参展商1000余家.相比于往年,本届博览会 ...

  4. 华为云工业智能体,做智能化最“硬核”

    随着物联网.云计算.大数据及AI等新兴技术的发展成熟,在"中国制造2025"的带动下,新兴技术与智能工业理念的融合正在推动中国制造业向数字化.网络化和智能化的方向转型.中国制造业要 ...

  5. 【工业智能】人工智能技术助力流程工业发展报告

    我国流程工业发展的历程中,自动化与信息化技术发挥了极其重要的作用,从集散控制系统(DCS)在流程企业中的普遍应用,到DCS/MES/ERP的实施,强化了管理信息化,实现了各个生产环节的信息管理,提升了 ...

  6. 工业智能摄像机的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告

    本文研究全球与中国市场工业智能摄像机的发展现状及未来发展趋势,分别从生产和消费的角度分析工业智能摄像机的主要生产地区.主要消费地区以及主要的生产商.重点分析全球与中国市场的主要厂商产品特点.产品规格. ...

  7. 工业AI落地,为什么选择华为云EI工业智能体?

    稳定可靠.帮你省钱又能把控全局,还有超越这个选择的吗? 时代在变化,传统工业也必须要变革. 这是老话,越来越多企业也意识到了这一点. 然而,正确的方法是什么?怎么做才合适?变革后能够给企业带来多大价值 ...

  8. 工业以太网交换机的产品性能有哪些呢?

    工业以太网交换机的使用非常广泛,有智能交通.电子警察.平安城市.工厂自动化等,如何在恶劣的室外作业环境中保障数据的稳定传输,对网络和通讯设备提出了极高的适应性要求,那么,工业以太网交换机的产品性能有哪 ...

  9. 三方应用集成_华为携手利尔达完成业界首个5G工业智能网关预商用集成验证

    在上海无线X Labs应用场景实验室,华为携手行业合作伙伴利尔达,开展业界首个基于华为MH5000通用工业模组的5G工业智能网关预商用产品集成验证,完成5G端到端网络通信服务打通和基于Profinet ...

最新文章

  1. linux查找技巧: find grep xargs amp;amp; linux系统信息查看大全
  2. Spring AOP,AspectJ,CGLIB 有点晕
  3. 如何在本地开发环境调试微信 JS-SDK
  4. [html]请描述HTML元素的显示优先级
  5. [C# 网络编程系列]专题十二:实现一个简单的FTP服务器
  6. 【mysql乱码】解决php中向mysql插入中文数据乱码的问题
  7. python语言标识符命名规则_Python标识符
  8. FileZillaServer创建FTP服务器
  9. 联想微型计算机怎么光盘启动,联想笔记本电脑win10怎么设置光盘启动
  10. 计算机画图星星怎么画,教你尺规作图画五角星!
  11. mysql模糊查询忽略大小写
  12. 【脚本教程】脱机的一些指令参考
  13. ANSYS | 螺栓模拟
  14. 【最强规则引擎】-- ICE
  15. BIOS功能调用表格
  16. C语言错误信息中文解释
  17. Idea21 每次运行(main)都会(buid)编译的问题
  18. 戴尔服务器安装系统出现蓝屏重启,服务器安装系统蓝屏原因_dell服务器安装系统设计.docx...
  19. Openjudge:鸡尾酒疗法
  20. 基于python的豆瓣FM(终端命令行界面)

热门文章

  1. SQL中将两个日期进行相减得到分钟或者秒
  2. 胜利vs50线跟vs100线区别_千兆网线和百兆网线有什么区别?千兆和百兆水晶头做法一样吗?...
  3. Redox bootloader实现分析
  4. Solaris、Linux和FreeBSD的内核比较
  5. CAD图纸转换该如何分享给Q Q、微信好友呢?
  6. 【ADC】ADC介绍
  7. 澳门科技大学计算机研究生就业,读研or就业?大四毕业季你将何去何从?
  8. 自动化运维管理平台TASKCTL如何在Docker安装部署
  9. cacti监控windows服务器
  10. 4+1口语语汇笔记7