1第四章数据挖掘中的主要方法--关联规则关联规则简介关联规则挖掘算法Microsoft关联规则挖掘模型简介Microsoft关联规则挖掘模型的使用小结2关联规则简介关联规则挖掘:从大量的数据中挖掘出有价值的描述数据项之间相互联系的有关知识。应用:购物篮数据分析,交差营销,价目表设置,聚类分类等等3购物篮分析:一个引发关联规则挖掘的例子如果我们想象全域是商店中可利用的商品的集合,则每种商品有一个布尔变量,表示该商品的有无。每个篮子则可用一个布尔向量表示。可以分析布尔向量,得到反映商品频繁关联或同时购买的购买模式。这些模式可以用关联规则的形式表示。例如,购买计算机也趋向于同时购买财务管理软件可以用以下关联规则表示:Computer->financial_management_software[support=2%,confidence=60%]关联规则是意义的,如果它满足最小支持度阈值和最小置信度阈值。4关联规则简介设I={i1,i2,...,im}是数据项的集合。设D为与任务相关的数据集合,也就是一个交易数据库,其中每个交易T是一个数据项子集合,即TI;每一个交易有一个标识符,称作TID。设A是一个数据项集,交易T包含A当且仅当AT。关联规则是形如A->B形式的蕴含式,其中AI,BI,并且A∩B=。5关联规则简介关联规则是形如A->B形式的蕴含式,其中AI,BI,并且A∩B=。规则A->B在交易数据集D中成立,具有支持度s和置信度c,其中s是D中交易包含A∪B(即,A和B二者)的百分比,它是概率P(A∪B);D中包含A的交易同时也包含B的百分比是c,这是条件概率P(B|A)。即同时满足最小支持度阈值(min_sup)和最小置信度阈值(min_conf)的规则称作强规则。为方便计,我们用0%和100%之间的值,而不是用0到1之间的值表示支持度和置信度。6关联规则简介一个数据项的集合称为项集。包含k个项的项集称为k-项集。集合{computer,financial_management_software}是一个2-项集。项集的出现频率是包含项集的交易数,简称为项集的支持度。项集满足最小支持度阈值,如果项集的出现频率大于或等于最小支持度阈值(min_sup)与D中交易总数的乘积。满足最小支持度阈值的所对应的交易记录数称为最小支持频度。满足最小支持度阈值的项集就称为频繁大项目集。频繁k-项集的集合通常记作Lk。7关联规则简介“如何由大型数据库挖掘关联规则?”关联规则的挖掘是一个两步的过程:1.找出所有频繁项集:根据定义,这些项集出现的频繁性至少和预定义的最小支持计数一样。2.由频繁项集产生强关联规则:根据定义,这些规则必须满足最小支持度和最小置信度。如果愿意,也可以使用附加的兴趣度度量。这两步中,第二步最容易。挖掘关联规则的总体性能由第一步决定。8关联规则挖掘路线市场购物分析只是关联规则挖掘的一种形式。事实上,有许多种关联规则。根据下面的标准,关联规则有多种分类方法:(1)根据关联规则所处理的具体值进行分类划分(2)根据规则中数据的维数进行分类划分(3)根据规则描述内容所涉及的抽象层次进行分类划分(4)根据关联规则所涉及的关联特性进行分类划分9关联规则挖掘路线(1)根据关联规则所处理的具体值进行分类划分如果规则考虑的关联是数据项的在与不在,则这种关联规则是一个布尔关联规则。Computer->financial_management_software[support=2%,confidence=60%]如果规则描述的是定量数据项或属性之间的关联,则它是一个定量关联规则。在这种规则中,数据项或属性的定量数值可以划分为区间范围。age(X,30...34)∩income(X,42K...48K)->buys(X,“computer“)10关联规则挖掘路线(2)根据规则中数据的维数进行分类划分如果关联规则中的项或属性每个只涉及一个维,则它是单维关联规则。buys(X,computer)->buys(X,financial_management_software)如果一个规则涉及两个或多个维,则它是多维关联规则。age(X,30...34)∩income(X,42K...48K)->buys(X,“computer“)11关联规则挖掘路线(3)根据规则描述内容所涉及的抽象层次进行分类划分有些关联规则挖掘方法可以在不同的抽象层发现关联规则。规则中涉及多个不同的抽象层,称所挖掘的规则集由多层关联规则组成。Age(X,”30...34”)->buys(X,”notebook_computer”)Age(X,”30...34”)->buys(X,”computer”)反之,如果在给定的规则集中,规则不涉及不同抽象层的项或属性,则该集合包含单层关联规则。12关联规则挖掘算法Apriori算法是一种挖掘频繁项集的基本算法。使用候选项集找频繁项集由频繁项集产生关联规则提高Apriori的有效性13Apriori算法:使用候选项集找频繁项集Apriori算法是一种最有影响的挖掘布尔关联规则频繁项集的算法。Apriori使用一种称作逐层搜索的迭代方法,k-项集用于探索(k+1)-项集。首先,找出频繁1-项集的集合。该集合记作L1。L1用于找频繁2-项集的集合L2,而L2用于找L3,如此下去,直到不能找到频繁k-项集。找每个Lk需要一次数据库扫描。该算法利用了一个基本性质:一个频繁项目集的任一子集必定也是频繁项目集,一个非频繁项目集的任一超集必定也是非频繁项目集。14Apriori算法:使用候选项集找频繁项集例6.1一个Apriori的具体例子。该例基于图6.2的AllElectronics的事务数据库。数据库中有9个事务,即|D|=9。Apriori假定事务中的项按字典次序存放。我们使用图6.3解释Apriori算法发现D中的频繁项集。15Apriori算法:使用候选项集找频繁项集“如何将Apriori性质用于算法?”为理解这一点,我们必须看看如何用Lk-1找Lk。下面的两步过程由连接和剪枝组成。1.连接步:为找Lk,通过Lk-1与自己连接产生候选k-项集的集合。该候选项集的集合记作Ck。2.剪枝步:Ck是Lk的超集;即,它的成员可以是,也可以不是频繁的,但所有的频繁k-项集都包含在Ck中。注意,Apriori算法使用逐层搜索技术,给定k-项集,我们只需要检查它们的(k-1)-子集是否频繁。151617由频繁项集产生关联规则一旦由数据库D中的事务找出频繁项集,由它们产生强关联规则是直接了当的(强关联规则满足最小支持度和最小置信度)。对于置信度,可以用下式,其中条件概率用项集支持度计数表示。其中,support_count(A∪B)是包含项集A∪B的事务数,support_count(A)是包含项集A的事务数。根据该式,关联规则可以产生如下:(1)对于每个频繁项集l,产生l的所有非空子集。(2)对于l的每个非空子集s,如果,则输出规则“s(l-s)”。其中,min_conf是最小置信度阈值。18由频繁项集产生关联规则例6.2它基于图6.2中AllElectronics事务数据库。假定数据包含集l={I1,I2,I5},可以由l产生哪些关联规则?l的非空子集有{I1,I2},{I1,I5},{I2,I5},{I1},{I5}。结果关联规则如下,每个都列出置信度。如果最小置信度阈值为70%,则只有2、3和最后一个规则可以输出,因为只有这些是强的。19提高Apriori的有效性“怎样能够提高Apriori的有效性?”已经提出了许多Apriori算法的变形,旨在提高原算法的效率。划分散列抽样动态的项目集计数层次结构序列模式依据日历的购物篮分析