1、知识发现(数据挖掘知识发现(数据挖掘) )第十二章第十二章 中国科学院计算技术研究所进化计算进化计算 Ev Evo olutionary Computationlutionary Computation 1谢谢您的观赏2019-8-292019-8-29谢谢您的观赏2内内 容容13.1 概述13.2 进化系统理论的形式模型13.3 达尔文进化算法13.4 遗传算法13.5 遗传算法的理论基础13.6 遗传算法的改进13.7 遗传机器学习分类器系统13.8 桶链算法13.9 规则发现系统13.10 进化策略13.11 进化规划2019-8-29谢谢您的观赏31 13.1 3.1 概概 述述 进化
2、计算是通过模拟自然界中生物进化机制进行搜索的一种算法。2019-8-29谢谢您的观赏4发展历史发展历史进化计算的研究起源于20世纪50年代。1965年,Holland首次提出了人工遗传操作的重要性,并把这些应用于自然系统和人工系统中。大约在同一时期:Rechenberg和Schwefel提出了进化策略。Fogel提出了进化规划。2019-8-29谢谢您的观赏5发展历史发展历史 1967年,Bagley在他的论文中首次提出了遗传算法这一术语,并讨论了遗传算法在自动博弈中的应用。1970年,Cavicchio把遗传算法应用于模式识别中。第一个把遗传算法应用于函数优化的是Hollstien。 201
3、9-8-29谢谢您的观赏6发展历史发展历史 1975年是遗传算法研究的历史上十分重要的一年。这一年,Holland出版了他的著名专著自然系统和人工系统的适应性该书系统地阐述了遗传算法的基本理论和方法,并提出了对遗传算法的理论研究和发展极为重要的模式理论(schemata theory),该理论首次确认了结构重组遗传操作对于获得隐并行性的重要性。 同年,DeJong完成了他的重要论文遗传自适应系统的行为分析。他在该论文中所做的研究工作可看作是遗传算法发展过程中的一个里程碑,这是因为他把Holland的模式理论与他的计算使用结合起来。 2019-8-29谢谢您的观赏7发展历史发展历史 1989 G
4、oldberg对遗传算法从理论上,方法上和应用上作了系统的总结。 1990年,Koza提出了遗传规划(Genetic Programming)的概念。(用于搜索解决特定问题的最适计算机程序)2019-8-29谢谢您的观赏8遗传算法与自然进化的比较遗传算法与自然进化的比较自然界染色体基因等位基因(allele)染色体位置(locus)基因型(genotype)表型(phenotype)遗传算法字符串字符,特征特征值字符串位置结构参数集,译码结构2019-8-29谢谢您的观赏9新达尔文进化理论的主要论点新达尔文进化理论的主要论点1) 个体是基本的选择目标;2) 随机过程在进化中起重大作用, 遗传变
5、异大部分是偶然现象;3) 基因型变异大部分是重组的产物, 特别是突变;4) 逐渐进化可能与表型不连续有关;5) 不是所有表型变化都是自然选择的必然结果;6) 进化是在适应中变化的, 形式多样, 不仅是基因的变化;7) 选择是概率型的, 而不是决定型的。2019-8-29谢谢您的观赏10进化计算的三大主流板块进化计算的三大主流板块lHolland提出的遗传算法(Genetic Algorithm)。lRechenberg和Schwefel提出的进化策略(Evolutionary Strategies)。lFogel提出的进化规划(Evolutionary Programming),又称为进化程序
6、设计。l本章将着重介绍遗传算法,对进化策略和进化规划只作简单介绍。2019-8-29谢谢您的观赏111 13.2 3.2 进化系统理论的形式模型进化系统理论的形式模型 进化在个体群体中起作用。瓦铤顿(Waddington)指出基因型和表型之间关系的重要性(Waddington 1974)。群体禁止异构环境。但是“后生环境”是多维空间。表型是基因型和环境的产物。然后表型通过异构“选择环境发生作用。注意,这种多维选择环境与后生环境空间是不同的。现在,适应性是表型空间和选择环境空间的产物。它经常被取作一维,表示多少子孙对下一代作出贡献。 基于这种想法,莫楞贝(Muhlenbein) 和肯德曼(Kin
7、dermann)提出了一种称为进化系统理论的形式模型(Muhlenbein 1989)。 2019-8-29谢谢您的观赏12 进化系统理论的形式模型进化系统理论的形式模型进化的主要过程后生环境遗传操作符选择环境gp2019-8-29谢谢您的观赏13进化系统理论的形式模型进化系统理论的形式模型),.,(1iinAaaagGS基因型空间:),.,(1IRppppPSim表型空间: 其中,g 是基因型 p 是表型。 基因gi的可能值称为等位基因。在门德尔(Mendel)遗传学中,假设每个基因有有限数的等位基因。2019-8-29谢谢您的观赏14进化系统理论的形式模型进化系统理论的形式模型,.,1kE
8、PEPEP 后生环境:),(EPgfpPSEPGSf:变换函数: IRtESpqi),(质量函数:这个变换函数给出了模型,说明表型的发展是通过基因与环境的交互作用。变换过程是高度非线性的。2019-8-29谢谢您的观赏15进化系统理论的形式模型进化系统理论的形式模型 IRtESpqi),(质量函数:质量函数q给出了具体选择环境ESi下表型的质量,其定义如下:质量定义适应度,用于达尔文选择。至今已有三种具体范例的通用模型,即 门德尔遗传学 遗传生态学 进化配子2019-8-29谢谢您的观赏16 门德尔遗传学门德尔遗传学在门德尔遗传学中,基因型被详细模型化,而表型和环境几乎被忽略。在遗传生态学中恰
9、好相反。进化配子论是从社会生物学导出的模型。 首先让我们讨论门德尔遗传学的选择模型。为了简单起见,我们假设一个基因具有n 等位基因a1,an。 二倍基因型以元组(ai,aj)为特征。 我们定义 pi,j 为总群体中基因型(ai,aj) 的频度。假设基因型与表型相等。质量函数给每个表型赋值。 q(ai,aj) = qi,j qi,j 可以被解释为出生率减去死亡率 2019-8-29谢谢您的观赏17 门德尔遗传学门德尔遗传学假设 pi,j是下一代表型(ai,aj) 的频度。然后达尔文选择根据选择方程调整表型的分布: Qqppjijiji,jijijipqQ, 是群体的平均适应度。Q2019-8-2
10、9谢谢您的观赏18 门德尔遗传学门德尔遗传学设 pi 是群体中等位基因的频率。如果 pi,j = pi pj那么,我们得到在 GS中的一个选择方程为 QQppiiijjjiipqQ,2019-8-29谢谢您的观赏19 门德尔遗传学门德尔遗传学这个离散的选择方程可以用连续方程近似: QQQpdtdpiii/ )(如果 qi,j = qj,i, 那么)(QQpdtdpiii2019-8-29谢谢您的观赏20 门德尔遗传学门德尔遗传学这个方程很容易被证明:0)(2)(222QVarQQEdtQd这个结果称作菲希尔(Fisher)基本定理。它说明平均适应度随适应度的差别呈正比例增加。实际上,全部可能的
11、基因型仅有一部分实现。这就是遗传操纵子探索基因型空间的任务,其个体数目相当小。这些操纵子是群体遗传变异性的来源。最重要的操纵子是突变和重组。2019-8-29谢谢您的观赏2113.3 13.3 达尔文进化算法达尔文进化算法根据定量遗传学,达尔文进化算法采用简单的突变/选择动力学。达尔文算法的一般形式可以描述如下:)/(),/( 是一代的双亲数目, 为子孙数目。整数 称作“混杂”数。如果两个双亲混合他们的基因,则 = 2。仅 是最好的个体才允许产生子孙。逗号表示双亲们没有选择,加号表示双亲有选择。 2019-8-29谢谢您的观赏2213.3 13.3 达尔文进化算法达尔文进化算法1) 建立原始种
12、体。2) 通过突变建立子孙。3) 选择:4) 返回到步骤(1)。11sgs 111ZsxxsgsZsxx)(max)(1xQxQi2019-8-29谢谢您的观赏23 遗传算法思想来源于生物进化过程, 它是基于进化过程中的信息遗传机制和优胜劣汰的自然选择原则的搜索算法(以字符串表示状态空间)。遗传算法用概率搜索过程在该状态空间中搜索,产生新的样本。13.4 13.4 遗传算法遗传算法2019-8-29谢谢您的观赏24遗传算法的特点遗传算法的特点特点:通用鲁棒次优解、满意解遗传算法能解决的问题:优化NP完全NP难高度复杂的非线性问题2019-8-29谢谢您的观赏25遗传算法遗传算法遗传算法先将搜索
13、结构编码为字符串形式, 每个字符串结构被称为个体。然后对一组字符串结构(被称为一个群体)进行循环操作。每次循环被称作一代,包括一个保存字符串中较优结构的过程和一个有结构的、随机的字符串间的信息交换过程。类似于自然进化,遗传算法通过作用于染色体上的基因寻找好的染色体来求解问题。2019-8-29谢谢您的观赏26 遗传算法遗传算法与自然界相似,遗传算法对求解问题的本身一无所知,它所需要的仅是对算法所产生的每个染色体进行评价,并基于适应值来选择染色体,使适应性好的染色体有更多的繁殖机会。在遗传算法中,位字符串扮演染色体的作用,单个位扮演了基因的作用,随机产生一个体字符串的初始群体,每个个体给予一个数
14、值评价,称为适应度,取消低适应度的个体,选择高适应度的个体参加操作。常用的遗传算子有复制、杂交、变异和反转。2019-8-29谢谢您的观赏27遗传算法与传统优化算法的主要不同遗传算法与传统优化算法的主要不同1) 遗传算法不是直接作用在参变量集上, 而是利用参变量集的某种编码;2) 遗传算法不是从单个点, 而是在群体中从一个点开始搜索;3) 遗传算法利用适应值信息, 无需导数或其它辅助信息;4) 遗传算法利用概率转移规则, 而非确定性规则。2019-8-29谢谢您的观赏28遗传算法的准备工作遗传算法的准备工作1) 确定表示方案;2) 确定适应值的度量;3) 确定控制该算法的参数和变量;4) 确定
15、怎样指定结果及程序运行结束的标准。2019-8-29谢谢您的观赏29基本遗传算法基本遗传算法基本遗传算法(Simple Genetic Algorithm:SGA)又称为简单遗传算法,只使用选择算子、交叉算子和变异算子这三种基本的遗传算子。其遗传操作简单、容易理解,是其它遗传算法的雏形和基础。基本遗传算法的构成要素:1、染色体编码方法:首先必须对问题的解空间进行编码,使之能用遗传算法进行操作。较常用的是二进制编码方法,现在使用非二进制编码的也逐渐增多。2、适应度函数(fitness function,又称为适应值适值函数)用来评价一个染色体的好坏。2019-8-29谢谢您的观赏30基本遗传算法
16、的构成要素基本遗传算法的构成要素3、遗传算子 选择算子(selection) :又称为复制算子。按照某种策略从父代中挑选个体进入下一代,如使用比例选择、轮盘式选择。 交叉算子(crossover):又称为杂交算子。将从群体中选择的两个个体,按照某种策略使两个个体相互交换部分染色体,从而形成两个新的个体。如使用单点一致交叉。 变异算子(mutation):按照一定的概率(一般较小),改变染色体中某些基因的值。2019-8-29谢谢您的观赏31杂交操作举例杂交操作举例),(tCvj10220201No OffspringPt. of interchangeCrossoverjCParentsjCO
17、ffspring1110#0#1#0111#0001#11#010#1000#00#110#01#10#100100100#011161711110#11#0001#0#0001#11#00#11#00#110#01#10#000#01111#01#10#2019-8-29谢谢您的观赏32变异操作变异操作简单的变异操作过程如下:每个位置的字符变量都有一个变异概率, 各位置互相独立。通过随机过程选择发生变异的位置:产生一个新结构 , 其中 是从对应位置 的字符变量的值域中随机选择的一个取值。 可以同样得到。lxxx,.,21txxxxxxssssssssa.111112221111xs1xkxx
18、ss,.,22019-8-29谢谢您的观赏33反转操作反转操作简单反转操作的步骤如下:1) 从当前群体中随机选择一个结构2) 从中随机选择两个数i和j, 并定义 i = mini,j, j=maxi,j;3) 颠倒a中位置i、j之间的部分, 产生新的结构lsssa.21ljijjissssssss.121212019-8-29谢谢您的观赏34基本遗传算法的构成要素基本遗传算法的构成要素4、运行参数N:群体大小,即群体中包含的个体的数量。T:遗传算法终止的进化代数。Pc:交叉概率,一般取为 0.40.99。Pm:变异概率,一般取为 0.00010.1 。2019-8-29谢谢您的观赏35基本遗传
19、算法基本遗传算法1. 随机产生一个由固定长度字符串组成的初始群体;2. 对于字符串群体,迭代地执行下述步骤,直到选种标准被满足为止:1) 计算群体中的每个个体字符串的适应值;2) 应用下述三种操作(至少前两种)来产生新的群体:复制: 把现有的个体字符串复制到新的群体中。杂交: 通过遗传重组随机选择两个现有的子字符串, 产生新的字符串。变异: 将现有字符串中某一位的字符随机变异。3. 把在后代中出现的最高适应值的个体字符串指定为遗传算法运行的结果。这一结果可以是问题的解(或近似解)。2019-8-29谢谢您的观赏36基本遗传算法流程图基本遗传算法流程图GEN=0概率地选择遗传操作随机创建初始群体
20、计算群体中每个个体的适应值i:=0显示结果结束GEN:=GEN+1是是否(转下页)i=N?GEN=M?12019-8-29谢谢您的观赏37概率地选择遗传操作根据适应值选择一个个体完成交叉i:=i+1i:=i+1复制个体p(r)选择(接上页)基于适应值选择两个个体把新的两个孩子加到群体中p(c)交叉变异p(m)把新的孩子加入到群体中完成变异根据适应值选择一个个体把变异后个体加入到群体中12019-8-29谢谢您的观赏38轮盘式选择轮盘式选择l首先计算每个个体 i 被选中的概率l然后根据概率的大小将将圆盘分为 n个扇形,每个扇形的大小为 。选择时转动轮盘,参考点r落到扇形i则选择个体i 。njij
21、fifp1)()(.p1p2pirip22019-8-29谢谢您的观赏39单点一致交叉单点一致交叉l首先以概率pc从种群中随机地选择两个个体p1、p2。在1, 2, . . . ,l内随机选择一个数i,作为交叉的位置,称为交叉点。然后将两个个体交叉点后面的部分交换。l例如: 0110 101100 0110 011001 1100 011001 1100 1011002019-8-29谢谢您的观赏40一致变异一致变异以概率pm对种群中所有个体的每一位进行变异。对于个体pi的第j位,在0,1的范围内随机地生成一个数r, 如果 r pm , 则对第j位取反,否则保持第j位不变。2019-8-29谢
22、谢您的观赏41遗传算法举例遗传算法举例问题:求(1)编码: 此时取均长为5,每个染色体(2)初始群体生成:群体大小视情况而定,此处设置为4,随机产生四个个体: 编码: 01101,11000,01000,10011 解码: 13 24 8 19 适应度: 169 576 64 361(3)适应度评价:31,0,)(2xxxfMax1111100000 x51 ,02)(xxfitness2019-8-29谢谢您的观赏42(4)选择:选择概率 个体: 01101,11000,01000,10011 适应度: 169 576 64 361 选择概率:0.14 0.49 0.06 0.31选择结果:
23、01101,11000,11000,10011(5)交叉操作:发生交叉的概率较大 哪两个个体配对交叉是随机的 交叉点位置的选取是随机的(单点交叉) 0110 1 01100 11 000 11 011 1100 0 11001 10 011 10 000ffPii/1170f.9.0,8.0cP遗传算法举例遗传算法举例2019-8-29谢谢您的观赏43(6)变异:发生变异的概率很小(7)新群体的产生: 保留上一代最优个体,一般为10%左右,至少1个 用新个体取代旧个体,随机取代或择优取代。 11000,11011,11001,10011(8)重复上述操作:说明:GA的终止条件一般人为设置; G
24、A只能求次优解或满意解。分析:按第二代新群体进行遗传操作,若无变异,永远也找不到最优解择优取代有问题。 若随机的将个体01101选入新群体中,有可能找到最优解。0001.0mP遗传算法举例遗传算法举例2019-8-29谢谢您的观赏4413.5 13.5 遗传算法的理论基础遗传算法的理论基础13.5.1 模式的定义 遗传算法的理论基础是遗传算法的二进制表达式及模式的含义。模式是能对染色体之间的相似性进行解释的模板。 定义1 设GA的个体 ,记集合 则称 为一个模式,其中是通配符。 即模式(schema)是含有通配符(*)的一类字符串的通式表达。每个“*”可以取“1”或者“0”。lBplS,*1
25、, 0Ss2019-8-29谢谢您的观赏45模式举例模式举例l模式 *10101110 与以下两个字符串匹配: 010101110 110101110l而模式 *1010110 与以下四个字符串匹配: 010100110 010101110 110100110 1101011102019-8-29谢谢您的观赏46模式的定义模式的定义l定义2 一个模式模式s s的阶的阶是出现在模式中的“0”和“1”的数目,记为o(s)。 如:模式“0*”的阶为1,模式“10*1*”的阶为3。l定义3 一个模式模式s s的长度的长度是出现在模式中第一个确定位置和最后一个确定位置之间的距离,记为 。 如:模式“01
26、*”的长度为1,模式“0*1”的长度为3。)( s2019-8-29谢谢您的观赏47 模式定理模式定理l假定在给定的时间步t,一个特定的模式s在群体P(t)中包含由m个代表串,记为m=m(s,t)。首先,我们暂不考虑交叉和变异操作。每个串根据适应值的大小获得不同的复制概率。串i的复制概率为:njijfifp1)()((1)2019-8-29谢谢您的观赏48 模式定理模式定理l则在群体P(t+1)中,模式s的代表串的数量的期望值为:njjfsfntsmtsmE1)()(),() 1,( 其中, 表示模式s在t时刻的所有代表串的适应值的均值,称为模式s的适应值。)(sf(2)2019-8-29谢谢
27、您的观赏49 模式定理模式定理l若记P(t)中所有个体的适应值的平均值为:njffnj1)((3) 则(2)式可以表示为:fsftsmtsmE)(),() 1,(2019-8-29谢谢您的观赏50 模式定理模式定理l(3)式表明,模式s的代表串的数目随时间增长的幅度正比于模式s的适应值与群体平均适应值的比值。即:适应值高于群体平均值的模式在下一代的代表串数目将会增加,而适应值低于群体平均值的模式在下一代的代表串数目将会减少。l假设模式的适应值为 ,其中c是一个常数,则 (3)式可写为:fc)1 ( 2019-8-29谢谢您的观赏51 模式定理模式定理(4) 上式表明,在平均适应值之上(之下)的
28、模式,将会按指数增长(衰减)的方式被复制。1)1 ()0 ,()1 (),()1 (),() 1,(tcsmctsmffctsmtsmE2019-8-29谢谢您的观赏52 模式定理模式定理 复制的结果并没有生成新的模式。因而,为了探索搜索空间中的未搜索部分,需要利用交叉和变异操作。 下面先探索交叉对模式的影响。 模式s1=“*1*0”和s2=“*10*” 交叉会改变模式的一部分,模式的长度越长,被破坏的概率越大。2019-8-29谢谢您的观赏53 模式定理模式定理 假定模式s在交叉后不被破坏的概率为ps,则: 若交叉概率为pc,则s不被破坏的概率为1)(1lsps1)(1lsppcs2019-
29、8-29谢谢您的观赏54模式定理模式定理(5) 所以,再考虑交叉时,(3)式可表示为 最后,考虑变异算子对模式的影响。变异算子以概率pm随机地改变个体某一位的值。只有当o(s)个确定位的值不被破坏时,模式s才不被破坏。1)(1)(),() 1,(lspfsftsmtsmEc2019-8-29谢谢您的观赏55模式定理模式定理 模式s在变异后不被破坏的概率: Pm1,可近似地表示为)(1somspp)(1soppms2019-8-29谢谢您的观赏56模式定理模式定理(6) 因此,考虑交叉和变异时,(3)式可表示为mcmcmcpsolspfsftsmpsolsppsolspfsftsmtsmE)(1
30、)(1)(),()(1)()(1)(1)(),() 1,(2019-8-29谢谢您的观赏57模式定理模式定理l由(6)我们得到一个重要的定理。l定理1 模式定理(Schema Theorem) 适应值在群体适应值之上的、长度较短的、低阶的模式在GA的迭代中将按指数增长方式被复制。2019-8-29谢谢您的观赏58积木块假设积木块假设lHolland和Goldberg在模式定理的基础上提出了“积木块假设”(Building Block Hypothesis):l低阶、长度较短、高于平均适应度的模式(积木块)在遗传算子的作用下,相互结合,能生成高阶、长度较长、适应度较高的模式,并得到全局最优解。2
31、019-8-29谢谢您的观赏59遗传算法的收敛性分析遗传算法的收敛性分析l算法的收敛性可以定义如下: 定义: 若算法在t时刻的种群xt满足 则称算法收敛到x0。l关于遗传算法的收敛性,Michalewicz证明了基于压缩原理的收敛性定理。而Rudolph证明了基于Markov链的收敛性定理。Xxxxtt00lim2019-8-29谢谢您的观赏60 遗传算法的改进遗传算法的改进遗传算法的局限性:遗传算法得到了广泛应用,但也暴露了一些问题,如:遗传算法在解决某些问题时速度较慢;遗传算法对编码方案的依赖性较强,算法的鲁棒性不够好等。这些问题主要归结为:(1)上位(epistasis)效应上位效应包括
32、两个方面:多基因性和基因多效性。2019-8-29谢谢您的观赏61 遗传算法的改进遗传算法的改进(2)编码方案最初使用最多的是二进制位串,但此类编码并不适合一些实际问题。现在人们已经探索了许多其它方案,如浮点表示、树形表示等等。(3)积木块假设积木块假设是否成立,是否一定存在短的、低阶的、高适应值的积木块?若构成问题最优解的所有低阶模式的适应值都较低,这是GA很难收敛到最优解,此类问题称为“欺骗问题”。2019-8-29谢谢您的观赏62 遗传算法的改进遗传算法的改进(4)早熟收敛即GA收敛到一个局部最优解。Schraudolph和Belew提出“动态参数编码”方案来解决早熟收敛问题。关于遗传算
33、法的一些改进措施,有兴趣的同学可查找相关资料。2019-8-29谢谢您的观赏63 遗传机器学习分类器系统遗传机器学习分类器系统l机器学习是人工智能的一个重要研究领域,也是人工智能的一个重要的应用领域。l遗传机器学习(Genetics Based Machine Learning, GBML)时将遗传算法与机器学习系统相结合的产物。2019-8-29谢谢您的观赏64遗传机器学习系统的一般框架遗传机器学习系统的一般框架任务子系统学习子系统任务检测器1dmd1eme任务效应器执行效应器执行检测器2019-8-29谢谢您的观赏65匹兹堡方法和密西根方法匹兹堡方法和密西根方法l遗传机器学习有两种重要的实
34、现方法:l一种是由匹兹堡(Pittsburgh)大学的De Jong和他的学生Smith提出的。该方法用整个规则集合表示一个个体,GAs维护一个包含一定数目的候选规则集的种群。这种方法称为匹兹堡方法。2019-8-29谢谢您的观赏66匹兹堡方法和密西根方法匹兹堡方法和密西根方法l另一种方法是由密西根(Michigan)大学的Holland和他的学生Reitman提出的。该方法每个个体表示一条规则,而整个种群就是规则集。这种方法称为密西根方法。lHolland提出的分类器系统采用的是密西根方法。2019-8-29谢谢您的观赏67分类器系统分类器系统Holland和他的同事提出了一种分类器系统的认
35、知模型,其中的规则不是规则集, 而是遗传算法操纵的内部实体。图11.3给出了分类器系统的一般结构, 从分类器系统看学习, 它由三层动作构成,即执行子系统、信用赋值子系统和发现子系统。2019-8-29谢谢您的观赏68 分类器系统分类器系统发现遗传算法信用赋值桶链执行分类器系统消息来自输入接口支付消息送出输出接口(目标)来自内部监控器的消息图 11.3 分类器系统的一般结构2019-8-29谢谢您的观赏69分类器系统分类器系统 执行子系统处在最低层, 直接与环境进行交互。它与专家系统相同,由产生式规则构成。但是, 它们是消息传送,高度平行。这类规则称作分类器。 分类器系统中的学习, 要求环境提供
36、反馈, 确认所希望的状态是否达到。系统将评价这些规则的有效性, 这些活动常常称作信用赋值。有些特定算法专门用来实现信用赋值, 例如, 桶链算法。 最后一层是发现子系统, 该系统必须产生新的规则, 取代当前用处不大的规则。通过系统累积的经验产生规则。系统根据适应值, 使用遗传算法选择、重组和取代规则。2019-8-29谢谢您的观赏70分类器系统分类器系统 分类器系统是平行执行、消息传递和基于规则的系统。在简单的方案中,消息采用规定的字母, 全部为固定长度。全部规则采用条件/动作形式。每个条件规定必须满足的信息, 每个动作规定当条件满足时所发送的消息。 为了方便, 假设消息采用长度为l的二进制字符
37、串记录, 字符采用子集1, 0, #。2019-8-29谢谢您的观赏71规则与消息规则与消息产生式规则:IF THEN 约定:条件的长度是固定的,用二进制数表示。定义:kimmmmmessageik,.,1,1 , 0,.,:21为通配符#,.,1,#, 1 , 0,.,:21kissssconditionikmessageconditionclassifier/: If sj = 1 or sj = 0, then mj = sj If sj = #, then mj can be either 1 or 0. 2019-8-29谢谢您的观赏72规则与消息规则与消息 满足要求的全部消息构成子
38、集, 即每个子集是在消息空间的一个超平面。分类器系统是由一组分类器 C1, C2, CN、一个消息表、输入接口、输出接口构成。每部分的主要功能如下: (1) 输入接口将当前环境状态翻译成标准消息。 (2) 分类器根据规则, 规定系统处理消息的过程。 (3) 消息表包含当前全部消息。 (4) 输出接口将结果消息翻译成效应器动作, 修改环境状态。2019-8-29谢谢您的观赏73分类器系统的基本结构分类器系统的基本结构分类器消息表(a)全部消息进行条件测试条件消息规约输出接口送到环境输入接口来自环境(a)(b)(b)选中分类器产生新消息2019-8-29谢谢您的观赏74分类器基本算法分类器基本算法
39、1) 将输入接口全部消息放入消息表。2) 将消息表中的全部消息与全部分类器所有条件比较, 记录所有匹配。3) 满足分类器条件部分的每组匹配, 将其动作部分所规定的消息送到新的消息表。4) 用新的消息表取代消息表中的全部消息。5) 将消息表中的消息翻译成输出接口的要求, 产生系统当前的输出。6) 返回到步骤(1)。2019-8-29谢谢您的观赏75简单的视觉分类器系统简单的视觉分类器系统视觉向量视野运动向量对象检测器11110消息1d2d3d4d2019-8-29谢谢您的观赏76性质检测器规定的值性质检测器规定的值1d1,如果移动对象0,其它),(32dd(0,0),如果对象在视野的中间(1,0
40、),如果对象在中心的左边(0,1),如果对象在中心的右边4d1,如果系统是对象的近邻0,其它5d1,如果对象很大0,其它6d1,如果对象是狭长的0,其它2019-8-29谢谢您的观赏77规则表示规则表示规则:IF 如果有“捕食(prey)”(small, moving,nonstriped object), 处于视野中间(centered), 非邻近 (nonadjacent),THEN 迅速移向对象 (ALIGN), (FAST).可以表示为:00#000001 / 0100000000000000, ALIGN, FAST.2019-8-29谢谢您的观赏78网络图网络图MOVING11dS
41、MALL05dNOT STRIPED06dNEAR010dFAR110d01001ALERT10001TARGET11001PORSUE11010APPROACH11011FLEE11100FREEZE10010DANGER2019-8-29谢谢您的观赏79网络图的规则表示网络图的规则表示MOVING和ALERT之间的箭头:00#1/01001#SMALL,NOT STRIPED and ALERT到TARGET的箭头:00#00#,01001#/10001#2019-8-29谢谢您的观赏80学习机制学习机制分类器系统使用两个学习机制, 桶链(bucket brigade) 算法。基于对系统的
42、贡献, 对现有规则分配一个信用值。 规则发现算法。这包括遗传算法,该算法可产生新规则,用于改善系统的知识库。2019-8-29谢谢您的观赏81 桶链算法桶链算法 桶链(bucket brigade) 算法基于对系统的贡献, 对现有规则分配一个信用值。主要解决多条规则同时要求被激活时的竞争问题。 例如:下面的情况下应该选择哪条规则。011101# #:0000# #00:000100# 0:11002019-8-29谢谢您的观赏82主要问题主要问题引入信用值后的两个问题: 当多条规则同时要求被激活时,如何解决竞争问题 对一规则被激活产生过作用的那些规则如何分配信用2019-8-29谢谢您的观赏8
43、3桶链算法桶链算法为解决上述两个问题,引入拍卖行和票据交易所:当有多个分类器获得匹配时,每个分类器要出一个与其强度成正比的叫价B叫价高的分类器被激活并允许发送消息,同时通过票据交易所,将其叫价B提供给激活的分类器。如此继续下去,一条规则可通过消费者获利(增加了强度),通过规则的不断激活形成一条消费者链,直至最终消费者(达到目标)直接从环境中得到补偿。若链中一条规则导致错误结论,则序列上该规则的强度将减弱,并且沿着序列回溯,从而产生新的消费者链2019-8-29谢谢您的观赏84举举 例例环境0111,强度为0,叫价系数为0.1。索引号分类器强度 101# #:0000200 200# 0:100
44、0200 311# #:1000200 4# #00:00012002019-8-29谢谢您的观赏85第一步第一步分类器 强度 消息 匹配 叫价01# #:0000 200 E 2000# 0:1000 20011# #:1000 200# #00:0001 2002019-8-29谢谢您的观赏86第二步第二步分类器 强度 消息 匹配 叫价01# #:0000 180 000000# 0:1000 200 1 2011# #:1000 200# #00:0001 200 1 20两条规则同时激活2019-8-29谢谢您的观赏87第三步第三步分类器 强度 消息 匹配 叫价01# #:0000 2
45、2000# 0:1000 180 110011# #:1000 200 2 20# #00:0001 180 0001 2 182019-8-29谢谢您的观赏88第四步第四步分类器 强度 消息 匹配 叫价01# #:0000 22000# 0:1000 21811# #:1000 180 1000# #00:0001 162 3 162019-8-29谢谢您的观赏89第五步第五步分类器 强度 消息 匹配 叫价 强度01# #:0000 220 22000# 0:1000 218 21811# #:1000 196 196# #00:0001 146 0001 206规则4达到目标获得补偿60。
46、2019-8-29谢谢您的观赏90投标改变分类器的强度投标改变分类器的强度在时间t满足C送去消息的分类器) ,() ,() ,() 1(3211tCBtCBtCBCV1C1C1C),(1tCB),(2tCB),(3tCB对在t-1作用的分类器投标在时间t对分类器C的支持2019-8-29谢谢您的观赏91分类器中的遗传算法分类器中的遗传算法遗传算法可产生新规则,用于改善系统的知识库。可以在三种情况下应用GA:1) 引入一个参数T(时间间隔),用于控制何时使用GA。2) 特殊情况时(如消息的条件都不能匹配)使用GA。3) 系统的性能太差。2019-8-29谢谢您的观赏92算法步骤算法步骤1) t=
47、0,随机生成集合Bt,|Bt|=M(大小);2) 计算Bt中全体分类器的平均强度Vt,对每个分类器赋予一个标准强度St(Cj)/Vt;3) 给Bt中的每个分类器Cj赋予一个与其标准强度成正比的概率,并根据Bt中的概率分布,从Bt中选取n个分类器,nM;4) 对每个分类器应用交叉算子,生成2n个分类器;5) 将Bt中的2n个强度最低的分类器用新生成的2n个取代;6) t=t+1,转(2)。2019-8-29谢谢您的观赏93算法说明算法说明1) 算法中S0(Cj)是预知的;2) 实现时考虑结束条件;3) 该算法是经典GA的变种,其中没有变异算子;4) 新分类器的强度是由旧分类器的强度决定的。201
48、9-8-29谢谢您的观赏94分类器强度调整算法分类器强度调整算法1) 将与所选动作相同的分类器形成子集 M,称作动作集 A。将不在 M中的其它分类器放在集合 NOTA中。2) 在A中的全部分类器强度减少一个分数e。3) 如果系统决策正确,则将赢利量R分配给A的强度;4) 如果系统决策错误,则将赢利量R(其中0RR)分配给 A的强度,从A的强度减少一个分数p。至少R和p中的一个为0。5) 从 NOTA中的强度减去一个分数t。2019-8-29谢谢您的观赏95 规则发现系统规则发现系统 在规则发现系统中, 学习经常是首先评价系统现有的规则质量, 然后进行修改。Grefenstette 研制了一种规
49、则发现系统RUDI。问题求解级由简化的分类器系统组成。学习级是对知识结构群体进行遗传算法操作, 每一个表示为一组规则表。知识结构的整个行为控制这些结构的复制。 在RUDI中, 信用赋值方法赢利共享规划(Profit-Sharing Plan,简称PSP) 和桶链算法(BBA) 对每个规则提供互补的效用信息。根据期望的外部奖励, PSP-强度对规则效用提供更精确的评估。当问题求解时它被用作冲突消解。与此相反, BBA-强度表示规则之间的动态相关性, 规则点火依次会聚到相似水平。这种测度可以用作一组协作规则的聚类。 2019-8-29谢谢您的观赏96 规则发现系统规则发现系统 Grefenstet
50、te 提出一种强度修改方案称作嬴利共享规划PSP。在这种方案中问题求解划分成情节, 按所接受的外部奖励区分。如果任何步情节在投标竞争中获胜, 则认为该规则在该情节活动。在情节t, PSP 修改每个活动规则Ri的强度 Si(t) 如下: ) 1()()0()1 ()(1ipbibSbtSittiiti Si(t + 1) = Si(t) -bSi(t) + bp(t), 其中, p(t) 称作在情节结束时所获得的外部奖励, 即当获得外部奖励,从每个活动规则搜集投标, 每个活动规则给出一部分外部奖励。考虑PSP 对给定规则Ri 的影响, 它按照方程得到:2019-8-29谢谢您的观赏97 规则发现