`
liyonghui160com
  • 浏览: 778499 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

关联规则—频繁项集Apriori算法

阅读更多



      频繁模式和对应的关联或相关规则在一定程度上刻画了属性条件与类标号之间的有趣联系,因此将关联规则挖掘用于分类也会产生比较好的效果。
关联规则就是在给定训练项集上频繁出现的项集与项集之间的一种紧密的联系。其中“频繁”是由人为设定的一个阈值即支持度 (support)来衡量,“紧密”也是由人为设定的一个关联阈值即置信度(confidence)来衡量的。这两种度量标准是频繁项集挖掘中两个至关重 要的因素,也是挖掘算法的关键所在。对项集支持度和规则置信度的计算是影响挖掘算法效率的决定性因素,也是对频繁项集挖掘进行改进的入口点和研究热点。
基于关联规则的分类主要分为以下以个步骤:
1.  对训练数据进行预处理(包括离散化、缺失值处理等)
2.  关联规则挖掘
     2.1  频繁项集挖掘
     2.2  关联规则生成
3.  规则处理
4.  对测试集进行测试
二、频繁项集挖掘
目前频繁项集挖掘已经有很多比较成熟的算法,在网上也可以找到相关的优秀论文或源代码。算法中最经典的莫过于Apriori算法,它可以算得上是频 繁项集挖掘算法的鼻祖,后续很多的改进算法也是基于Apriori算法的。但是遗憾的是Apriori算法的性能实在不咋的,当当玩具玩玩还可以,但是即 使如此,该算法却是频繁项集挖掘必须要掌握的入门算法。
题外话:关健是要了解算法的思想,你可以不了解一个东西是怎样具体实现的,但是一定得了解它是如何出来的。这样遇到相关的问题,你可以有一个参考的 解决方法,或者在关键时刻可以跟别人忽悠忽悠。当然,了解思想的最佳途径就是自己动手去实现实现了,哪怕实现得不咋样,起码思想掌握了,也是个不小的收 获。
下面就要具体介绍如何利用Apriori算法进行频繁项集挖掘了。

(1)相关概念
项集:“属性-值”对的集合,一般情况下在实际操作中会省略属性。
候选项集:用来获取频繁项集的候选项集,候选项集中满足支持度条件的项集保留,不满足条件的舍弃。
频繁项集:在所有训练元组中同时出现的次数超过人工定义的阈值的项集称为频繁项集。
极大频繁项集:不存在包含当前频繁项集的频繁超集,则当前频繁项集就是极大频繁项集。
支持度:项集在所有训练元组中同时出现的次数。
置信度:形如A->B,置信度为60%表示60%的A出现的同时也出现B。
k项集:项集中的每个项有k个“属性-值”对的组合。

(2)两个定理
i:连接定理。若有两个k-1项集,每个项集按照“属性-值”(一般按值)的字母顺序进行排序。如果两个k-1项集的前k-2个项相同,而最后一 个项不同,则证明它们是可连接的,即这个k-1项集可以联姻,即可连接生成k项集。使如有两个3项集:{a, b, c}{a, b, d},这两个3项集就是可连接的,它们可以连接生成4项集{a, b, c, d}。又如两个3项集{a, b, c}{a, d, e},这两个3项集显示是不能连接生成3项集的。要记住,强扭的瓜是不甜的,也结不了果的。
ii:频繁子集定理。若一个项集的子集不是频繁项集,则该项集肯定也不是频繁项集。这个很好理解,举一个例子,若存在3项集{a, b, c},如果它的2项子集{a, b}的支持度即同时出现的次数达不到阈值,则{a, b, c}同时出现的次数显然也是达不到阈值的。因此,若存在一个项集的子集不是频繁项集,那么该项集就应该被无情的舍弃。倘若你舍不得,那么这个项集就会无情 的影响你的效率以及处理器资源,所以在这时,你必须无情,斩立决!

(3)Apriori算法流程
    1. 扫描数据库,生成候选1项集和频繁1项集。
    2. 从2项集开始循环,由频繁k-1项集生成频繁频繁k项集。
           2.1  频繁k-1项集生成2项子集,这里的2项指的生成的子集中有两个k-1项集。使如有3个2项频繁集{a, b}{b, c}{c, f},则它所有的2项子集为{{a, b}{b, c}}{{a, b}{e, f}}{{b, c}{c, f}}
        2.2  对由2.1生成的2项子集中的两个项集根据上面所述的定理 i 进行连接,生成k项集。
        2.3  对k项集中的每个项集根据如上所述的定理 ii 进行计算,舍弃掉子集不是频繁项集即不在频繁k-1项集中的项集。
        2.4  扫描数据库,计算2.3步中过滤后的k项集的支持度,舍弃掉支持度小于阈值的项集,生成频繁k项集。
    3.  当当前生成的频繁k项集中只有一个项集时循环结束。

      关联规则(Association Rules)是反映一个事物与其他事物之间的相互依存性和关联性,是数据挖掘的一个重要技术, 用于从大量数据中挖掘出有价值的数据项之间的相关关系。 其中关联规则挖掘的最经典的例子就是沃尔玛的啤酒与尿布的故事 ,通过对超市购物篮数据进行分析,即顾客放入购物篮中不同商品之间的关系来分析顾客的购物习惯,发现美国妇女们经常会叮嘱丈夫下班后为孩子买尿布,30%-40%的丈夫同时会顺便购买喜爱的啤酒,超市就把尿布和啤酒放在一起销售增加销售额。
二.基本概念
关联规则挖掘是寻找给定数据集中项之间的有趣联系。如下图所示:


 
其中,I={I1,I2,…Im}是m个不同项目的集合,集合中的元素称为项目(Item)。项目的集合I称为项目集合(Itemset),长度为k的项集成为k-项集。设任务相关的数据D是数据库事务的集合,其中每个事务T是项的集合,使得 T ⊆ I 。每个事务有一个标识符TID;设A是一个项集,事务T包含A当且仅当 A⊆I ,则关联规则形式为A=>B(其中 A ⊂ I , B ⊂ I ,并且 A ∩ B = ∅)。
 
在关联规则度量中有两个重要的度量值:支持度和置信度 。对于关联规则R:A=>B,则:
1. 支持度(suppport ): 是交易集中同时包含A和B的交易数与所有交易数之比。
Support(A=>B)=P(A∪B)=count(A∪B)/|D|
2. 置信度(confidence ): 是包含A和B交易数与包含A的交易数之比。
Confidence(A=>B)=P(B|A)=support(A∪B)/support(A)


 
  
如上图中数据库D,包含4个事务,项集I={I1,I2,I3,I4,I5},分析关联规则:I1=>I4,事务1、4包含I1,事务4同时包含I1和I4。
支持度support=1/4=25%(1个事务同时包含I1和I4,共有4个事务)指 在所有交易记录中有25%的交易记录同时包含I1和I4项目
置信度confidence=1/2=50%(1个事务同时包含I1和I4,2个事务包含I1)指 50%的顾客在购买I1时同时还会购买I4
 
使用关联规则对购物篮进行挖掘,通常采用两个步骤进行: 下面将通超市购物的例子对关联规则挖掘进行分析。
a.找出所有频繁项集(文章中我使用Apriori算法>=最小支持度的项集)
b.由频繁项集产生强关联规则(>=最小支持度和最小置信度)
三.举例:Apriori算法挖掘频繁项集
Apriori算法是一种对有影响的挖掘布尔关联规则频繁项集的算法,通过算法的连接和剪枝即可挖掘频繁项集。 补充频繁项集相关知识: K-项集:指包含K个项的项集; 项集的出现频率:指包含项集的事务数,简称为项集的频率、支持度计数或计数; 频繁项集:如果项集的出现频率大于或等于最小支持度计数阈值,则称它为频繁项集,其中频繁K-项集的集合通常记作L k 。
下面直接通过例子描述该算法:如下图所示(注意Items已经排好序),使用Apriori算法关联规则挖掘数据集中的频繁项集。(最小支持度技术为2)
 

 
具体过程如下所示:


 
具体分析结果:
第一次扫描:对每个候选商品计数得C1,由于候选{D}支持度计数为1<最小支持度计数2,故删除{D}得频繁1-项集合L1;
第二次扫描:由L1产生候选C2并对候选计数得C2,比较候选支持度计数与最小支持度计数2得频繁2-项集合L2;
第三次扫描:用Apriori算法对L2进行连接和剪枝产生候选3项集合C3的过程如下:
1.连接:
C3=L2  (连接)L2={{A,C},{B,C},{B,E},{C,E}}  {{A,C},{B,C},{B,E},{C,E}}={{A,B,C},{A,C,E},{B,C,E}}
2.剪枝:
{A,B,C}的2项子集{A,B},{A,C}和{B,C},其中{A,B}不是 2项子集L2,因此不是频繁的,从C3中删除;
{A,C,E}的2项子集{A,C},{A,E}和{C,E},其中{A,E}不是2项子集L2,因此不是频繁的,从C3中删除;
{B,C,E}的2项子集{B,C},{B,E}和{C,E},它的所有2项子集都是L2的元素,保留C3中.
经过Apriori算法对L2连接和剪枝后产生候选3项集的集合为C3={B,C,E}. 在对该候选商品计数,由于等于最小支持度计数2,故得频繁3-项集合L3,同时由于4-项集中仅1个,故C4为空集,算法终止。
四.举例:频繁项集产生强关联规则
强关联规则是指:如果规则R:X=>Y满足support(X=>Y)>=supmin(最小支持度,它 用于衡量规则需要满足的最低重要性)且confidence(X=>Y)>=confmin(最小置信度,它表示关联规则需要满足的最低可靠 性)称关联规则X=>Y为强关联规则,否则称关联规则X=>Y为弱关联规则。

 


例:下图是某日超市的购物记录(注意Items已经排好序),使用上面叙述的Apriori算法实现了挖掘频繁项集,其中频繁项集I={i1,i2,i5}为频繁3-项集合L3,求由I产生哪些强关联规则?(最小支持度阈值为20%,最小置信度阈值为80%)



 


I的非空子集有{i1,i2}、{i1,i5}、{i2,i5}、{i1}、{i2}和{i5}。
结果关联规则如下,每个都列出置信度
1).i1 ∧i2=>i5 ,共10个事务;5个事务包含i1,i2;2个事务包含i1,i2和i5   confidence=2/5=40%,support=2/10=20%
2).i1 ∧i5=>i2 ,共10个事务;2个事务包含i1,i5;2个事务包括i1,i2和i5   confidence=2/2=100%,support=2/10=20%
3).i2 ∧i5=>i1 ,共10个事务;2个事务包含i2,i5;2个事务包含i1,i2和i5    confidence=2/2=100%,support=2/10=20%
4).i1=>i2 ∧i5 ,共10个事务;7个事务包含i1;2个事务包含i1,i2和i5       confidence=2/7=28%,support=2/10=20%
5).i2=>i1 ∧i5 ,共10个事务;8个事务包含i2;2个事务包含i1,i2和i5       confidence=2/8=25%,support=2/10=20%
6).i5=>i1 ∧i2 ,共10个事务;2个事务包含i5;2个事务包含i1,i2和i5       confidence=2/2=100%,support=2/10=20%
因最小置信度阈值为80%,最小支持度阈值为20%,则236规则符合要求,是频繁项集I={i1,i2,i5}产生的强关联规则且可以输出。


(自己的推测:如果给定的是最小支持度计数为2,则有10个事务,最小支持度阈值supmin=2/10=20%)

 

 

在实际应用中订单每天增加,我们采用增量的方式计算,去掉支持度的限制。

 

  • 大小: 9.9 KB
  • 大小: 9.9 KB
  • 大小: 8.7 KB
  • 大小: 43.3 KB
  • 大小: 16.2 KB
分享到:
评论

相关推荐

    apriori算法求频繁项集和关联规则 mvc架构 java版

    标题"apriori算法求频繁项集和关联规则 mvc架构 java版"提及了两个主要概念:Apriori算法和MVC架构,并指明这是使用Java语言实现的。Apriori是一种经典的挖掘频繁项集和生成关联规则的数据挖掘算法,而MVC(Model-...

    关联规则挖掘算法apriori算法的实现

    2. **剪枝策略**:在生成候选项集时,Apriori算法通过提前排除不可能成为频繁项集的项来减少计算量。这是通过维护一个候选集并检查每个项集的支持度来实现的。如果一个项集的支持度低于预设的最小支持度阈值,那么其...

    apriori 频繁项集与关联规则 算法的matlab实现

    本篇文章将详细讲解Apriori算法及其在MATLAB中的实现,包括频繁项集的生成和关联规则的发现。 首先,我们要理解Apriori算法的基本原理。Apriori算法的核心思想是“频繁项集的闭包性质”和“剪枝策略”。它基于一个...

    c++实现关联规则Apriori算法

    Apriori算法是这一领域的经典算法,由Rakesh Agrawal和Ramyakrishnan Srikant于1994年提出,它的核心思想是基于频繁项集的性质来剪枝搜索空间,减少计算复杂性。 C++是一种广泛应用于系统编程、应用编程、游戏开发...

    使用Apriori算法进行关联规则挖掘的实验报告与代码实现

    Apriori算法的基本思想是通过迭代生成不同支持度的频繁项集,然后基于这些频繁项集生成强关联规则。首先,我们需要理解几个关键概念: 1. **项集**:一个或多个项目的集合,例如{"牛奶", "面包"}。 2. **支持度**:...

    基于Apriori算法的关联规则挖掘系统的设计与实现_大数据apriori_关联规则_#大数据论文_Apriori算法_

    Apriori算法的工作原理基于“频繁项集”的概念,即如果一个项集在数据库中出现的次数超过预设的支持度阈值,那么它就是频繁的。算法首先找出所有单个项目的频繁项集,然后通过连接这些频繁项集来生成更长的候选项集...

    apriori算法挖掘关联规则

    **关联规则挖掘与Apriori算法** 关联规则挖掘是数据挖掘领域的一个重要概念,它旨在发现数据集中项集之间的有趣关系。例如,在超市购物数据中,可能会发现“购买尿布”的顾客往往也会“购买啤酒”,这种关系即为...

    大数据经典算法Apriori讲解.ppt

    Apriori算法是挖掘布尔关联规则频繁项集的算法 Apriori算法利用频繁项集性质的先验知识(prior knowledge),通过逐层搜索的迭代方法,即将k-项集用于探察(k+1)-项集,来穷尽数据集中的所有频繁项集。 先找到频繁1-...

    关联规则apriori算法

    3. `cal_apriori.m`:可能是Apriori算法的主要实现部分,计算频繁项集。 4. `as.txt`、`2017-all.txt`、`2017-xia.txt`、`xdata1.txt`:这些可能是不同的训练数据集,可能包含不同时间段或不同场景的交易记录。 5. `...

    关联规则apriori算法fptree算法

    关联规则Apriori算法和FP-Tree算法都是关联规则挖掘的重要技术,可以用来发现频繁项集和关联规则。关联规则的评价也是非常重要的,需要使用支持度、置信度和 Lift 等指标来评价关联规则的强度。

    Apriori算法及其实现

    Apriori算法是一种经典的关联规则挖掘算法,它主要用于发现数据集中项集之间的频繁模式和强关联规则。在商业智能、市场分析、医学诊断等领域,Apriori算法的应用极为广泛,因为它能够帮助决策者从海量数据中提取出有...

    Apriori算法实现及实验报告

    Apriori算法是一种经典的关联规则学习算法,广泛应用于数据挖掘中的频繁项集发现。该算法由R. Agrawal和R. Srikant在1994年提出,主要用于找出数据库中项集之间的有趣关系,如购物篮分析,即发现哪些商品经常一起被...

    Apriori算法matlab代码实现,带数据集和使用说明

    Apriori算法是一种经典的挖掘频繁项集和发现关联规则的数据挖掘方法,由R. Agrawal和R. Srikant于1994年提出。它主要用于从大规模交易数据库中找出有趣的、有意义的关联关系,如“购买尿布的顾客往往也会购买啤酒”...

    1.rar_association_关联规则_关联规则 matlab_关联规则Apriori算法

    Apriori算法是关联规则学习中最著名的算法之一,由 Agrawal 和 Srikant 在1994年提出,主要用于从交易数据库中发现频繁项集和强规则。 **关联规则** 关联规则描述了在数据集中两个或多个项目之间存在的频繁共同出现...

    人工智能和机器学习之关联规则学习算法:Apriori算法:频繁项集的生成方法.docx

    人工智能和机器学习之关联规则学习算法:Apriori算法:频繁项集的生成方法.docx

    人工智能和机器学习之关联规则学习算法:Apriori算法:频繁项集的生成方法.pdf

    人工智能和机器学习之关联规则学习算法:Apriori算法:频繁项集的生成方法.pdf

    关联规则挖掘算法-Apriori算法原理

    Apriori算法的基本思想是通过对数据库的多次扫描来计算项集的支持度,发现所有的频繁项集从而生成关联规则。Apriori算法对数据集进行多次扫描,第一次扫描得到频繁1-项集L1,第k(k&gt;1)次扫描首先利用第(k-1)次扫描...

    人工智能-机器学习-关联规则分析-Apriori算法实例-挖掘电影导演的关联规则

    2. 应用Apriori算法:设置最小支持度阈值,该阈值定义了一个项集被视为频繁的最低标准。算法会迭代地查找频繁项集,并构建各种长度的候选集。 3. 生成关联规则:一旦找到频繁项集,就可以从中创建关联规则。关联...

    数据挖掘中关联规则经典算法Apriori

    总结来说,Apriori算法是数据挖掘关联规则中的基础方法,通过迭代生成频繁项集并挖掘强关联规则,为商业决策、市场分析等领域提供了有力工具。尽管存在效率问题,但通过优化和改进,Apriori算法仍然在许多场景下发挥...

Global site tag (gtag.js) - Google Analytics