规则引擎以及blaze 规则库的集成初探之三——Blaze规则引擎和SRL

原文地址:http://jefferson.iteye.com/blog/68604

在上面介绍利用JSR94的api使用的章节中,我们使用的具体引擎的实现是一个商业产品,如果想了解Drools的使用,这里有一份入门的参考文章:http://blog.csdn.net/tigerflower/archive/2006/09/06/1185922.aspx。由于关于blaze的文章很少,这里根据经验,简单介绍一下它的实现。

blaze是由blazeSoft公司提供的产品,由于是商业产品,因此专门IDE非常强大,现在流行的版本是Blaze Advisor5.5和Blaze Advisor6.x.。blaze的开发模式有编程式开发的好处,也有声明式开发的好处。在开发的IDE,你看到的是一般传统的编程式编程的IDE一样,保存后的原代码是xml格式的文件。看过DRool 的规则语言,它有一些固定的xml标签,有不同的含义,你必须掌握,而在blaze的编程里面,你就像写java代码一样。

在介绍blaze的建立和开发之前,现简单介绍一下规则语言的语法。规则语言,名称SRL (全称为Standard Rule Language),据自称,是一个类English的语言,也就是让业务人员也看得懂的语言。我们看一个例子:theAccount‘s balance is between $00.00 and $500.00 。在java中的表示是theAccount.balance>=00 and theAccount.balance<=500,当然,在srl里面也支持像前面那句在java中的类似用法。看另外一个例子,是一个类的声明:
a Vehicle is an object;其实,它的语法规则很简单,也易学,学习代价非常小。在使用中我们可以发现,它一样是一个面向对象的语言,提供了原子类型、基本的类库和内置的方法等等,与java的兼容好,java代码的嵌入方便。
现在来看看具体的用法:
类的声明,当然包括属性:

a Vehicle is an object with {
a speed : a real,
a size : a string,
a unit_price : a real }.

在java中的使用是:
class Vehicle
{
 public double speed;
 public String size;
 public double unit_price;
}
过过瘾,举一个声明一个对象实例的例子:
就刚才Vehicl类为例:
a vehicle1 is some Vehicle initially a vehicle1 initially{
set  speed to 10.0,size  to 20,unit_price to $100000.00}
或者更加简洁的:
myCar is a Vehicle initially{
speed=10.0,size="2m" ,unit_price=$100000.00}
非常灵活,而且你不必担心语法的松散带来许多错误,IDE可以识别所以的语法错误。

对象数组:
Accounts is a fixed array of 4 Account
initially { it[0] = checkingAccount. }
这里声明了一个对象数组,名为Accounts,数组的类型是Account,大小为4,其中第一项指向的对象引用是checkingAccount.
同样我们看另外一个例子:
itinerary is an array of city
initially { it.append(city2),
it.append(city3),
it.append(city4).
}.
利用了array的内置方法append,it代表当前对象,相当于java中的this关键字。

声明数组的其他例子,数组下标可以是string类型,也可以是整数类型等等,随意定义,这像java类库的Map及其子类,可谓功能强大。
airports is an association from
string to string initially
{ it["New York"] = "JFK",
it["San Francisco"] = "SFO",
it["Los Angeles"] = "LAX".
}.
这段话什么意思呢?解释一下前半部分。
airports是对象名,也就是对象数组名,an association from是关键字,from后面的string是数组的key的类型,to后面的string是制定这个数组是属于string类型的数组。
为了增加感性认识,再举一个例子:
Products is an association from
integer to Product initially {
it[094] = someProduct. }

对象属性的声明:
a speed : a real,
a size : a string,
a unit_price : a real
....
如果属性是数组,则为an address : some array of string。

对象的初始化,上面的介绍中,大家也大概清楚了,且看代码段:
initially { temp = 98.6, firstName = "Bill" }
initially { it.setTemp(98.6),
firstName = "Bill" }
initially { Deposit(newAccount, amount) }.
第二个代码段,调用了类内部的方法。第三个代码段,调用了Deposit方法。

Enumeration,声明为:a[n] enumerationName is one of { itemName,
itemName[, itemName ]... } .
例如:a color is one of { red, green, blue }.
有必要说说Enumeration的作用。
上面定义了一个Enumeration,名为color,那么在application中定义了一个属性,为color,如下:
an application is an object with {
a customer : a string,
a color,
an amount: an integer }
initially { amount = 0, color = red }.
那么,这个application的对象的属性color将有三个标准值: red, green, blue,你可以初始化指定为red。挺像一个有值约束的自定义类型。

Pattern的声明:
且看例子:
theCustomer is any Customer.
theAccount is any Account in accountArray.
seniorMale is any person such that
(it.age > 65 and it.gender is male).
我们知道,一个类可以有多个instance,我们可以制定一个对象,它的值限制在某个对象或者对象数组的某个或者某几个对象实例,那么可以定义一个patten。这就是典型的条件匹配,简化成一种类型。
上面的例子,theCustomer指定是任何一个Customer的对象,theAccount指定为accountArray数组中的任何一个Account对象,seniorMale指定为年龄大于65并且为女性的person对象。
这种模式匹配,就像我们用到的正则表达式一样,用起来威力无穷矣:
说一个例子:
假定有一个类Account,在某个ruleset中,拥有n个Account的对象:a1,a2,...,an,,那么你可以声明一个patten如下:
accountPattern is any Account.
在rules中的条件匹配,你可以这样使用:
if accountPattern.balance > 0
then accountPattern.positiveBalance = true
那么它的作用相当于:
if a1.balance > 0
then a1.positiveBalance = true
if a2.balance > 0
then a2.positiveBalance = true
...
if an.balance > 0
then an.positiveBalance = true

最后看看原始类型的声明:
i is an integer.
startDate is a date initially ‘1/31/99‘.
Today is a date.
Today = calendar().currentDate().
price is a money initially $1684.37.
再看看具体的变量声明为Enumeration的话,应为:sample is a color initially blue.
color为上述的a color is one of { red, green, blue }.

常用的也就这些,象event阿,ruleset的定义自看文档,在GUI中不用srl去定义。

现在说说,rule也就是规则匹配吗,主要用到的是条件匹配句式。且看:
if theForm’s name starts with "req" then...
if theForm’s name ends with "req" then...
if theApplicant’s lastName is blank then...
else ……
上述的就是if-then-else句式,没什么特别。其中theForm’s name,theForm对象的属性 name是string类型,因此对string类型的操作 从句子中可以看到。
if 语句中的boolean操作有:not | or | and
比较操作符有:is | = | <> | < | > | <= | >=
对数字的操作有:+ | - | * | / | div | mod 例如:
19 / 5 = 3.8
19 div 5 = 3
19 mod 5 = 4

其他流程控制语句:
case语句:
select countryofOrigin of product
case China : apply ChinaTariffRules
case Japan : apply JapanTariffRules
case Thailand : apply ThailandTariffRules
otherwise : print("No tariffs apply.").

迭代for语句:
for each customer such that (it.balance > 10000)
do { print(it.name " qualifies for promotion.").
apply PromotionRuleset. }
for each Invoice in customer.invoices
such that it.balance
do { sum += it.amount. }

While_Do语句:
while (portfolioValue = unavailable)
do { portfolioValue = promptReal("What
is the value of your portfolio?") }

Until do语句:
until (productsRemaining = 0)
do { apply CheckPriceRuleset(product).
productsRemaining -= 1. }

异常的捕捉和处理:
try Statement_Block
catch a[n] exceptionClassName with Statement_Block
[finally Statement_Block]
例如:
try { customer.addAccount(payment) }
catch an accountException with
{ print("Account not created because " it).}

其实,都跟java相似,没多少区别。

(blaze的规则引擎的介绍继续……)

时间: 2024-08-26 03:21:23

规则引擎以及blaze 规则库的集成初探之三——Blaze规则引擎和SRL的相关文章

探索推荐引擎内部的秘密,第 2 部分: 深入推荐引擎相关算法 - 协同过滤(转)

第 2 部分: 深入推荐引擎相关算法 - 协同过滤 本系列的第一篇为读者概要介绍了推荐引擎,下面几篇文章将深入介绍推荐引擎的相关算法,并帮助读者高效的实现这些算法. 在现今的推荐技术和算法中,最被大家广泛认可和采用的就是基于协同过滤的推荐方法.它以其方法模型简单,数据依赖性低,数据方便采集 , 推荐效果较优等多个优点成为大众眼里的推荐算法“No.1”.本文将带你深入了解协同过滤的秘密,并给出基于 Apache Mahout 的协同过滤算法的高效实现.Apache Mahout 是 ASF 的一个

Node.js-视图引擎【1】-Swig集成express的安装与配置

node.js视图引擎,选来选去发现Swig最符合我的胃口哈哈. 一.安装Swig视图引擎 npm install -g swig 二.在node.js代码中配置如下 var app = require('express')(); var swig = require('swig'); app.engein('html', swig.renderFile); app.set('view engine', 'html'); app.set('views', __dirname + '/views'

探索推荐引擎内部的秘密,第 3 部分: 深入推荐引擎相关算法 - 聚类

聚类分析 什么是聚类分析? 聚类 (Clustering) 就是将数据对象分组成为多个类或者簇 (Cluster),它的目标是:在同一个簇中的对象之间具有较高的相似度,而不同簇中的对象差别较大.所以,在很多应用中,一个簇中的数据对象可以被作为一个整体来对待,从而减少计算量或者提高计算质量. 其实聚类是一个人们日常生活的常见行为,即所谓"物以类聚,人以群分",核心的思想也就是聚类.人们总是不断地改进下意识中的聚类模式来学习如何区分各个事物和人.同时,聚类分析已经广泛的应用在许多应用中,包

(转载)虚幻引擎3--【UnrealScript教程】章节一:17.可在引擎中编辑的默认属性

var() 数据类型 变量名:var(XXX) 修改这个类别class MyUSGame extends actorplaceable; var() int i;var (physics) int p;var (Display) float d; function PostBeginPlay(){ } defaultproperties{i=100;} 如图出现了在脚本里所定义的变量和值 主要用来改颜色,亮度等,方便关卡设计.

关系型数据库——MySQL

[MySQL架构图] MySQL简要架构图如下图所示,引擎层以插件方式集成了不同的存储引擎,它们共用Server层对外提供服务.   连接器:用于连接管理,进行身份认证及权限相关的管理.(登录MySQL) 查询缓存区:执行查询语句时,先从缓存区查询.(该功能V8.0之后移除) 分析器:未命中缓存时,对SQL进行词法分析.语法分析. 优化器:按照MySQL认为的最优方案,生成执行计划. 执行器:执行SQL,并从存储引擎返回数据. 存储引擎:存储数据,提供读写接口 [MySQL存储引擎] V5.5之

drools规则引擎初探

1.drools是什么 Drools是为Java量身定制的基于Charles  Forgy的RETE算法的规则引擎的实现.具有了OO接口的RETE,使得商业规则有了更自然的表达. Rule是什么呢? 一条规则是对商业知识的编码.一条规则有 attributes ,一个 Left Hand Side ( LHS )和一个 Right Hand Side ( RHS ).Drools 允许下列几种 attributes : salience , agenda-group , no-loop , au

Java规则引擎及JSR-94[转]

规则引擎简介 Java规则引擎是推理引擎的一种,它起源于基于规则的专家系统.      Java规则引擎将业务决策从应用程序代码中分离出来,并使用预定义的语义模块编写业务决策.Java规则引擎接受数据输入,解释业务规则,并根据规则作出业务决策.从这个意义上来说,它是软件方法学在"关注点分离"上的一个重要的进展.      JSR-94规范定义了独立于厂商的标准API,开发人员可以通过这个标准的API使用Java规则引擎规范的不同产品实现.但值得注意的是,这个规范并没有强制统一规则定义的

规则引擎入门

什么是规则引擎? 规则引擎由推理引擎发展而来,是一种嵌入在应用程序中的组件,实现了将业务决策从应用程序代码中分离出来,并使用预定义的语义模块编写业务决策.接受数据输入,解释业务规则,并根据业务规则做出业务决策. 参考: http://baike.baidu.com/link?url=BfAR-sxz1ryvOZ4uSVCqn9Csy51U5qCUaIomAQBogPE7FOxbbDB-2iXWR6N8FReIkoNNdc-Hk4y0sxKWpknWd_ 规则引擎和工作流引擎有什么区别? 工作流引

探索推荐引擎内部的秘密,第 1 部分: 推荐引擎初探

"探索推荐引擎内部的秘密"系列将带领读者从浅入深的学习探索推荐引擎的机制,实现方法,其中还涉及一些基本的优化方法,例如聚类和分类的应用.同时在理论讲解的基础上,还会结合 Apache Mahout 介绍如何在大规模数据上实现各种推荐策略,进行策略优化,构建高效的推荐引擎的方法.本文作为这个系列的第一篇文章,将深入介绍推荐引擎的工作原理,和其中涉及的各种推荐机制,以及它们各自的优缺点和适用场景,帮助用户清楚的了解和快速构建适合自己的推荐引擎. 信息发现 如今已经进入了一个数据爆炸的时代,