Rete算法学习笔记

     最近在研读Jena的推理机源代码,Jena推理机的实现主要也是用的RETE算法,所以研究了RETE算法的基本流程。RETE算法是由Forgy在他的论文《A Fast Algorithm for the Many Pattern/Many Object Pattern Match Problem》中提出的。

 

1 RETE算法的基本思想 

RETE算法是一个用于产生式系统的高效模式匹配算法。在一个产生式系统中,被处理的数据叫做working memory,用于判定的规则分为两个部分LHSleft-hand-side)和RHSright hand side),分别表示前提和结论。主要流程可以分为以下步骤:

(1)Match:找出符合LHS部分的working memory集合

(2)Confilict resolution:选出一个条件被满足的规则

(3)Act:执行RHS的内容

(4)返回1  

RETE算法主要改进Match的处理过程,通过构建一个网络进行匹配。

2
算法详细描述

 

RETE网络主要分为两个部分,alpha网络和beta网络。如下图所示。

 

(1)alpha网络:过滤working memory,找出符合规则中每一个模式的集合,生成alpha memory(满足该模式的集合)。有两种类型的节点,过滤type的节点和其他条件过滤的节点(我觉得这两种是依照需要设定的,也并不一定需要两种节点)。

(2)Beta网络:有两种类型的节点Beta MemoryJoin Node。前者主要存储Join完成后的集合。后者包含两个输入口,分别输入需要匹配的两个集合,由Join节点做合并工作传输给下一个节点。

3
 匹配过程描述

 

 

(1)导入需要处理的事实到facts集合中。

(2)如果facts不为空,选择一个fact进行处理。否则停止匹配过程。

(3)选择alpha网的第一个节点运行(建立网络的时候设定的),通过该节点则进入alpha网的下一个节点,直到进入alpha memory。否则跳转到下一条判断路径。

(4)alpha memory的结果加入到beta memory中,如果不为Terminal节点,则检测另一个输入集合中是否存在满足条件的事实,满足则执行join,进入到下一个beta memory重复执行(3)。若另一个输入集合无满足条件的事实,返回到(2)。如果该节点为Terminal节点,执行ACT并添加到facts中。


4 用一个例子描述过程

(1)现在WME中有以下这些事实。

w1:(B1 ^on B2)

w2:(B1 ^on B3)

w3:(B1 ^color red)

w4:(B2 ^on table)

w5:(B2 ^left-of B3)

w6:(B2 ^color blue)

w7:(B3 ^left-of B4)

w8:(B3 ^on table)

w9:(B3 ^color red)


(2)下面描述规则

下面是三条匹配条件

C1: (<x> ^on <y>)

C2:(<y> ^left-of <z>)

C3:(<z> ^color red)

下面是规则要满足的所有条件,即所有LHS

p1 has conditions C1^C2^C3

p2 has conditions C1^C2^C4^C5

p3 has conditions C1^C2^C4^C3

 

(3)推理描述

  暂且忽略图中的红色节点(用于判定类型)。那么,根据Ci,图中的蓝色alpha结点应该有三种,分别判定on,left-of和color。则黄色的alpha memory中包含三个集合,分别是满足C1:{w1 w2 w4 w8}

满足C2:{w5 w7}

满足C3:{w2 w6 w9}

     以p1为例,首先以C1,C2为输入,在绿色Dummy Input节点中进行操作,并传入到梅红色beta momory中,此时这个节点存储的是(w1^w5,w2^w7)。然后以这个集合和C3为输入,操作得出w1^w5^w9,此时发现没有更多的模式需要匹配,到达Terminal节点,匹配结束。这样就得到满足规则的集合组合了。

     接下来的时间要研究Jena中Rete算法的具体实现方式。

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Rete算法的流程可以分为以下几个步骤: 1. 构建规则网络:首先,根据规则的条件和操作,构建一个规则网络。规则网络由节点和连接线组成。节点表示条件或操作,连接线表示节点之间的关系。 2. 匹配阶段:在匹配阶段,将待匹配的事实或事件输入到规则网络中。事实会从输入节点进入规则网络,并根据条件节点的规则进行匹配。 3. 判断匹配结果:当事实在规则网络中进行匹配时,会经过一系列的条件节点。如果事实满足某个条件节点的条件,则该条件节点会发出一个信号,表示条件满足。 4. 构建令牌:当条件节点发出信号时,会生成一个令牌。令牌是一种数据结构,用于记录匹配的路径和状态信息。 5. 传播令牌:生成的令牌会根据连接线进行传播。令牌会根据连接线的方向和约束条件传递给下一个节点。 6. 规则匹配:令牌继续在规则网络中传播,直到达到输出节点。当令牌到达输出节点时,执行相应的操作,例如输出结果或触发某些行为。 7. 更新网络状态:在执行操作后,可能会导致规则网络状态的改变。如果有新的事实输入,规则网络会根据新的输入更新令牌的状态,并重新进行匹配和传播。 8. 循环匹配:Rete算法通常会进行多次匹配迭代,直到所有的事实都被匹配完或达到某个终止条件。 通过这样的流程,Rete算法能够高效地进行规则匹配,避免了重复计算和匹配的问题。 希望这个算法流程的解释对你有帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值