使用CKRule实现PVC配方计算
1,PVC计算的基本原理
配方员设计好配方,再进行抽象提炼,会出现相对于软件而言可以理解的逻辑,如属性的概念,对厂企生成的PVC产品而言,一般都有产品大类名称,花纹,颜色,长度,宽度,厚度等概念,这对于软件而言,就是一个对象,该对象是描述订单的对象。而配方计算出来的结果,如原料名称,质量比分量,重量等信息就是物料清单对象。
配方计算的过程就是这样的一个过程。
结构化标准配方,就是教科书上面的知识,如
PVC |
100 |
DINP |
40 |
Caco3 |
10 |
HSt |
1 |
Sb2O3 |
4 |
这此是基础数据,生产某产品,并且油份在一定的区间就要调用这个配方。
而半结构化表格配方规则,一般是厂企特有的内容,设置时可以自定义一个属性进行归纳总结,如使用特征码来表达增加某些原料,如增加透明度时,执行这个表格:
特征码 |
增透明剂编码 |
份量 |
B1 |
TM-001 |
1 |
B2 |
TM-002 |
0.5 |
B3 |
TM-003 |
1.5 |
表示,如果当前的配方对象的特征为B2时,就要在物料集合中增加透明剂TM-002,份量为1。而特征码和增透明剂的编码都是厂企按一定的规则进行编写的。
非结构化表达式是指,某些配方确实不好表达时使用,如产品名第2个字符为X,则增加DINP份量2。也就是针对表达内容非常随便的自然语言的处理。
2,PVC计算三大问题
PVC计算过程中遇到了结构化标准配方、半结构化表格规范及非结构化表达式规则三个类型的问题。下面使用最简单的例子表达
结构化标准配方
PVC |
100 |
DINP |
40 |
Caco3 |
10 |
HSt |
1 |
Sb2O3 |
4 |
半结构化表格配方范
特征码 |
增透明剂编码 |
份量 |
B1 |
TM-001 |
1 |
B2 |
TM-002 |
0.5 |
B3 |
TM-003 |
1.5 |
非结构化表达式规则
产品名第2个字符为X,则增加DINP份量2。
3,CKRule界面设置
物料清单会被抽象出来成为一个对象。该对象有名称,份量,重量等内容
在传入传出对象上,则定义了配方计算对象主要的属性,如产品名,订单号,特性,颜色,油份,花纹,长度,宽度,厚度,密度,重量等等。
半结构化表格规范,使用了CKRule中的决策表逻辑,目前只增加了一个增透剂使用规范,规范中标明,如果一定的特征码就要增加增透剂一定数据。
在处理非结构化规则时,使用了CKRule的客户规则池功能,定义了多个关键字,并针对规则编写过程中的实际情况增加了两个方法,取第N个字符和增加份量。
客户规则池相关代码
取第N个字符 |
var _result = ""; if(!string.IsNullOrEmpty(字符串)){ if(字符串.Length > 索引 && 索引 > -1){ _result = 字符串.Substring(索引,1); } } return _result; |
增加份量 |
AddRow(物料集合,x=>{ x.名称 = 物料名称; x.份量 = 份量; }); |
最后就是在总规则中初始化结构化,半结构化,非结构化数据。并执行决策表和规则池。
主规则相关代码
初始化结构化标准数据 |
var _table = LookDB(@" select Name as 名称,MPercent as 份量,0 as 重量 from MatBase a inner joinFml b on a.BaseId=b.Id where b.ProductName ='" + 产品名 + "'"); Fill(物料集合,_table); |
初始化半结构化表格数据 |
var _table = LookDB(@"select TableName,Prop1,Prop2,Prop3,Prop4,Prop5,Prop6 from TableSet"); InitTable(_table); |
初始化非结构化规则表 |
var _table = LookDB(@"select '' as id, sindex as ""index"", '' as returnType, 'Get' + name as propname, 1 as codestyle, ifcode, 0 as thencodeisscript, thencode, 0 as priority, '' as execstep from poolset "); InitPool(_table); |
执行决策表和规则池 |
ExeTable(); ExePool(); |
4,业务系统中的抽象
上一节已经介绍了PVC配方计算在CKRule上面的定义,而CKRule不是直接面对终端客户的,业务系统才是面对客户的,也就是说客户不会直接操作CKRule,为了业务系统界面友好性和设置的需要,定义业务系统中的对象,数据表和公式编辑界面显得相当的必要了。
下面将介绍对象的定义
配方对象定义
[Serializable]
public class FmlCond
{
public string Id { get; set; }
public string ProductName { get; set; }
public string OrderNo { get; set; }
public string Color { get; set; }
public string Spe { get; set; }
public double Oil { get; set; }
public string Flower { get; set; }
public double Length { get; set; }
public double Width { get; set; }
public double Depth { get; set; }
public double Density { get; set; }
public double Weight { get; set; }
private List<物料定义> _物料集合 = new List<物料定义>();
public List<物料定义> MatList
{
get { return _物料集合; }
set { _物料集合 = value; }
}
}
[Serializable]
public class 物料定义
{
public string Name { get; set; }
public double MPercent { get; set; }
public double Weight { get; set; }
}
扩展说明:配方计算也许不仅仅有这些内容,还可能有更多的,如生产班组,部门,班长,时间,压纹层数,如果层数变化那厚度也会变化,而这些的定义都必须是业务系统的开发员进行的,也就是说,计算的过程可能是多变的,不简单的是上面的这样。但只要划清楚流程图,做好调用设计和对象设计,这些都不是问题,CKRule还没有集成流程功能,这可能会有一些的影响,但做常规的规则计算已经很充分了。关键还是看模型者的设计。
数据表设计
决策表数据设计,事实上,相对通用的设置也许是最合理的,下面的设计是很简单的,但这样设计即使决策表的初始化非常的方法。
TableName |
Prop1 |
Prop2 |
Prop3 |
Prop4 |
Prop5 |
Prop6 |
Prop7 |
增透剂规范 |
B1 |
TM-001 |
1 |
|
|
|
|
增透剂规范 |
B2 |
TM-002 |
0.5 |
|
|
|
|
增透剂规范 |
B3 |
TM-003 |
1.5 |
|
|
|
|
对照一个CKRule上面的设置
代码如下:
特征码 |
Prop1 |
!string.IsNullOrEmpty(特性) && 特性 == value |
增透剂编码 |
Prop2 |
AddRow(物料集合,x=>{ x.名称 = value; x.份量 = CDouble(Row.Cells["Prop3"].Value); }); |
主规则中的初始化逻辑
var _table = LookDB(@"select TableName,Prop1,Prop2,Prop3,Prop4,Prop5,Prop6 from TableSet");
InitTable(_table);
客户规则池数据表
SIndex |
Name |
IfCode |
ThenCode |
ElseCode |
Priority |
ExecStep |
0 |
按订单第2位加增塑剂 |
取第N个字符(订单号,1) == "X" |
增加份量("DINP",2); |
|
10 |
|
主规则中的初始化逻辑
var _table = LookDB(@"select
'' as id,
sindex as ""index"",
'' as returnType,
'Get' + name as propname,
1 as codestyle,
ifcode,
0 as thencodeisscript,
thencode,
0 as priority,
'' as execstep
from poolset
");
InitPool(_table);
配方表
ID |
ProductName |
OrderNo |
Spe |
Color |
Oil |
Flower |
Length |
Width |
Depth |
Density |
Weight |
1 |
CKP-01 |
T2X14042000 |
B1 |
CL-01 |
45 |
FL-33 |
1000 |
21 |
0.4 |
|
|
2 |
CKP-02 |
TX2X014041000 |
B1 |
CL-01 |
32 |
FL-65 |
400 |
22 |
0.3 |
|
|
3 |
CKP-03 |
TX2014045000 |
B2 |
CL-02 |
44 |
FL-12 |
300 |
23 |
0.8 |
|
|
4 |
CKP-04 |
T2014043500 |
B3 |
CL-03 |
27 |
FL-11 |
400 |
24 |
0.9 |
|
|
5 |
CKP-05 |
T2014044000 |
B2 |
CL-06 |
50 |
FL-44 |
2000 |
19 |
1 |
|
|
配料表
BaseId |
Name |
MPercent |
1 |
PVC |
100 |
1 |
DINP |
15 |
1 |
Caco3 |
5 |
1 |
CK-001 |
20 |
2 |
CK-YL01 |
20 |
2 |
CK-YL02 |
20 |
3 |
PVC |
100 |
3 |
DOP |
19 |
3 |
CK-001 |
8 |
3 |
CK-002 |
2 |
3 |
CK-003 |
3 |
4 |
PVC |
100 |
4 |
DOP |
4 |
4 |
CK-032 |
1 |
4 |
CK-044 |
2 |
4 |
CK-055 |
3 |
4 |
Caco3 |
4 |
5 |
PVC |
100 |
5 |
DINP |
20 |
5 |
CK-422 |
6 |
5 |
CK-478 |
7 |
编码说明:一般而言,在厂企中都使用编码,方便规范化管理和保密的需要,CK-478如果不是厂企的员工,根本不知道是什么,如果有保密配方,那这个编码就应该只有几个重要人员知道是什么。但本文而言,作者是因为不太熟悉配方设计,一般都是塑料化工科班出身的人才配得出来,所以才使用编码。但不影响阅读。
5,业务系统界面显示
配方计算主界面由配方列表和物资明细组成,其中配方主表数据来自来Fml数据表,而物资明细信息来自于MatBase表,Fml相当于配方订单表(含生产信息),而MatBase就是物料清单,这两个表有关联关系。
事实上,还应该有一个产品-物料表,即生产何种产品就使用何种物资,这就是之前提及的结构化的标准配方数据。
配方规则编写表,只写了一个最简单的规则,如前面所述通过订单编号来判断份量。这只是一个简单,还需要业务系统开发商的不断扩展,以便适应不同厂商的要求。这需要一个抽象和提炼的过程,是与客户不断接触的过程中完善和改进的对象模型。
源代码下载, http://www.ckrule.com/cn/solution/business/195.html
使用CKRule实现PVC配方计算的更多相关文章
- 浅谈PVC塑料配方计算软件的设计
1, 配方设计与配方计算 题目是配方计算,不是配方设计,设计是需要有深厚的塑料知识才可以做的,即生产什么塑料产品,需要放各种原料是什么,各自比较是多少,遇到什么情况下就要多放什么,少放什么.配方设计不 ...
- 使用CKRule规则引擎处理多变业务
1, 多变业务 开发系统时,有没有试过下面的情况,如果你试过,那可以考虑一下使用规则引擎了. 序号 问题 举例 1 业务规则来自于一个或多个表格 商店的会员积分表,停车场的计费标准,快递费的计算表,客 ...
- 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解
欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯云容器服务团队 源码为 k8s v1.6.1 版本,github 上对应的 commit id 为 b0b7a323cc5a4a ...
- 业务与IT技术
最近听一个同事又再次提问关于业务比技术重要,是真的吗? 今天我们再来看一下. 一,什么是业务? 业务意指某种有目的的工作或工作项目.技术可以指人类对机器.硬件或人造器皿的运用,但它也可以包含 ...
- ckrule规则编辑器在wpf中的使用
当前,ckrule的IDE和业务管理系统都是由winform开发的,规则编辑器也只提供了winform的版本,所以很多的朋友都提出意见,要有wpf的版本.wpf的界面设置和管理都更加的方便. 事实上可 ...
- kubernetes系列11—PV和PVC详解
本文收录在容器技术学习系列文章总目录 1.认识PV/PVC/StorageClass 1.1 介绍 管理存储是管理计算的一个明显问题.该PersistentVolume子系统为用户和管理员提供了一个A ...
- 13.kubernetes之pv,pvc,configmap(带补充实例)
管理存储是管理计算的一个明显问题.该PersistentVolume子系统为用户和管理员提供了一个API,用于抽象如何根据消费方式提供存储的详细信息.为此,我们引入了两个新的API资源:Persist ...
- pv和pvc状态
原文地址:https://kubernetes.cn/topics/46 API Server 和 PVController API Server: 这个组件提供对API的支持,响应REST操作,验证 ...
- Kubernetes 中的pv和pvc
原文地址:http://www.cnblogs.com/leidaxia/p/6485646.html 持久卷 PersistentVolumes 本文描述了 Kubernetes 中的 Persis ...
随机推荐
- angularJs路由的使用
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Python之freshman05
一:内建模块 time和datetime(http://www.jb51.net/article/49326.htm) 在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 ...
- mac 添加环境变量
1.Mac系统的环境变量,加载顺序为: a. /etc/profile b. /etc/paths c. ~/.bash_profile d. ~/.bash_login e. ~/.profile ...
- oracle数据库修改密码
忘记了数据库的登录密码,oracle数据库无法登录了. 先删除原先的密码保存文件: del E:\oracle_app\Administrator\product\11.2.0\dbhome_1\da ...
- 最小生成树----prim算法的堆优化
题目描述 如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出orz 输入输出格式 输入格式: 第一行包含两个整数N.M,表示该图共有N个结点和M条无向边.(N<=5000,M<= ...
- Bootstrap4 导航栏元素居右
Bootstrap 4正解: .ml-auto元素居右 .mr-auto元素居左 在某度上查了半小时还是没查出什么名堂,搜出来的方法大多都是Bootstrap3的,实测pull-right或navba ...
- PIE SDK打开网络地图数据
1. 数据介绍 网络地图数据是在线地图服务发布出来的数据,其支持数据的网络查看和传输,极大的促进了GIS的发展. 目前PIE SDK支持百度地图.谷歌地图.高德地图.天地图.Bing地图.ArcGIS ...
- Spark on Yarn运行错误:Yarn application has already ended! It might have been killed or unable to launch application master
Spark on Yarn模式运行错误: bin/spark-shell --master yarn --deploy-mode client #报错 查看8088页面上的工作日志 错误原因:在执 ...
- HttpServlet的请求转发理解
一个http请求的流转,其实主要涉及到五部分的内容,第一部分就是request所包含的参数,也就是request.getAttribute能获取的东西:第二部分是request所携带的内容实体,这部分 ...
- 白话SpringCloud | 第九章:路由网关(Zuul)的使用
前言 介绍完分布式配置中心,结合前面的文章.我们已经有了一个微服务的框架了,可以对外提供api接口服务了.但现在试想一下,在微服务框架中,每个对外服务都是独立部署的,对外的api或者服务地址都不是不尽 ...