大家知道MapReduce是奠定GOOGLE成功基础的三大技术法宝之一(另外两个是PageRank和BigTable),现在MapReduce方法论已经在网络开发甚至在企业开发中得到广泛的应用,而本文则探讨MapReduce在MES PLC编程中的应用。

目前PLC和自动化技术在MES的应用中非常关键,通过对PLC的集成,MES得以打通执行层、控制层、设备层,在一些汽车制造公司,甚至专门搭建IT PLC或MASTER PLC,以实现PMC、ANDON、AVI、EPS等高度复杂的业务模块,以及数以千计的外部设备(拉绳/按钮/灯)的集成。

因此,对于MES业务而言,IT PLC的重点不是过程控制,而是复杂业务逻辑的处理,以及大量I/O设备的读写。

由于上述原因,IT PLC内部运行的FB/FC就会非常多,如果不认真规划的话,OB1里调用关系就会非常混乱,因而需要对程序的结构进行严谨的设计。

本文试以ANDON为例,说明MapReduce在PLC编程上的借鉴。

 

首先是Map。

Map应体现在两个方面,一是程序结构。

如下图体现了非常清晰的调用关系,在OB1中只需要做一些业务模块的声明:

MES与PLC之间通信代码_MES与PLC之间通信代码

第二个方面是配置关系的定义,如线和工位的对应关系,工位和拉绳/灯的对应关系。

如下图所示,可以用数组建立线和工位的对应关系,然后把拉绳和灯的编号作为工位属性配置:

MES与PLC之间通信代码_IT_02

MES与PLC之间通信代码_MES与PLC之间通信代码_03

 因而我们可以用遍历数组的方式得到线对应的所有工位,然后根据工位属性得到对应的拉绳编号和灯编号。

 

再来看Reduce。

从FC40000 ANDON主FC以下,我们又看到了以下几类业务处理过程:

- 对于线的处理

- 对于工位的处理

- 对于拉绳的处理

- 对于灯的处理

 

我们可以分别编写4个FC来进行相应的处理。

- FC40100处理线的逻辑,包含两个变量:线编号和工位数量。

- FC40101处理工位的逻辑,包含变量:工位编号。

- FC40111处理拉绳的逻辑,包含变量:拉绳编号和拉绳状态。

- FC40121处理灯的逻辑,包含变量:灯编号。

 

经由以上处理,我们就得到了一个非常简洁的调用结构:

MES与PLC之间通信代码_数组_04

MES与PLC之间通信代码_MES与PLC之间通信代码_03

具体过程为:

- FC40000依次调用各条线FC40100。

- FC40100调用本线对应所有工位的FC40101。

- FC40101调用工位对应拉绳的FC40111。

- FC40101根据拉强绳返回的状态值FLAG,决定是否调用灯的FC40121。

 

总结一下,本文中用MapReduce处理PLC程序结构的要点:

- OB1/FC的结构要清晰、有层次。

- 业务模型通过DB中的数组等结构体现关系。

- 业务过程FC要参数化、可重用。