Python数据挖掘学习笔记(7)频繁模式挖掘算法----FP-growth

本文主要是介绍Python数据挖掘学习笔记(7)频繁模式挖掘算法----FP-growth,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、相关原理

       FP-Growth算法是韩嘉炜等人在2000年提出的关联分析算法,它采取如下分治策略:将提供频繁项集的数据库压缩到一棵频繁模式树(FP-tree),但仍保留项集关联信息。在算法中使用了一种称为频繁模式树(Frequent Pattern Tree)的数据结构。FP-tree是一种特殊的前缀树,由频繁项头表和项前缀树构成。FP-Growth算法基于以上的结构加快整个挖掘过程。

       FP-growth算法只需要对数据库进行了两次扫描,而Apriori算法对于每个潜在的频繁项集都会扫描数据集判定给定模式是否频繁,因此FP-growth算法的速度要比Apriori算法快。在小规模数据集上,这不是什么问题,但是当处理大规模数据集时,就会产生很大的区别。大致流程如下图:

                                        

       关于FP-growth算法需要注意的两点是:

     (1)该算法采用了与Apriori完全不同的方法来发现频繁项集

     (2)该算法虽然能更为高效地发现频繁项集,但不能用于发现关联规则。

       从FP-growth算法挖掘频繁项集这个流程图中可以看出,FP-growth算法主要有两个步骤,即构建FP树以及从FP树中挖掘频繁项集。

       其他相关原理可查看相关文章,推荐机器学习实战一书。

二、编写代码

1、数据初始化方法:

#创建数据集
def loadSimpDat():simpDat = [['r', 'z', 'h', 'j', 'p'],['z', 'y', 'x', 'w', 'v', 'u', 't', 's'],['z'],['r', 'x', 'n', 'o', 's'],['y', 'r', 'x', 'z', 'q', 't', 'p'],['y', 'z', 'x', 'e', 'q', 's', 't', 'm']]return simpDat#数据格式化
def createInitSet(dataSet):retDict = {}for trans in dataSet:#print(trans)fset = frozenset(trans)#print(fset)retDict.setdefault(fset, 0) #返回指定键的值,如果没有则添加一个键#print(retDict)retDict[fset] += 1#print(retDict)return retDict

2、FP的数据结构类:

#FP树的数据结构类
class treeNode:def __init__(self, nameValue, numOccur, parentNode):self.name = nameValue       #名字变量self.count = numOccur       #计数变量(频率)self.nodeLink = None        #链接相似元素项self.parent = parentNode    #当前父节点self.children = {}          #用于存放子节点def inc(self, numOccur): #对count变量增加给定值self.count += numOccur def disp(self, ind=1):  #将树以文本形式显示,主要是方便调试。print(' '*ind, self.name, ' ', self.count)for child in self.children.values():child.disp(ind+1)         #子节点向右缩减

3、创建FP树的相关方法:

#更新头指针表
def updateHeader(nodeToTest, targetNode):  while (nodeToTest.nodeLink != None):  nodeToTest = nodeToTest.nodeLinknodeToTest.nodeLink = targetNode#FP树的生长函数
def updateTree(items, myTree, headerTable, count):if items[0] in myTree.children:  myTree.children[items[0]].inc(count)else:  myTree.children[items[0]] = treeNode(items[0], count, myTree)if headerTable[items[0]][1] == None:headerTable[items[0]][1] = myTree.children[items[0]]else:updateHeader(headerTable[items[0]][1], myTree.children[items[0]])if len(items) > 1:  updateTree(items[1:], myTree.children[items[0]], headerTable, count)#创建FP树,默认最小支持度为1,将根据支持度对数据进行第一次过滤
def createTree(dataSet, minSup=1):headerTable = {}#第一次遍历数据集, 记录每个数据项的支持度for trans in dataSet:for item in trans:headerTable[item] = headerTable.get(item, 0) + 1#根据最小支持度过滤lessThanMinsup = list(filter(lambda k:headerTable[k] < minSup, headerTable.keys()))for k in lessThanMinsup:del(headerTable[k])freqItemSet = set(headerTable.keys())#如果所有数据都不满足最小支持度,返回None, Noneif len(freqItemSet) == 0:return None, Nonefor k in headerTable:headerTable[k] = [headerTable[k], None]myTree = treeNode('φ', 1, None)#第二次遍历数据集,构建fp-treefor tranSet, count in dataSet.items():#根据最小支持度处理一条训练样本,key:样本中的一个样例,value:该样例的的全局支持度localD = {}for item in tranSet:if item in freqItemSet:localD[item] = headerTable[item][0]if len(localD) > 0:#根据全局频繁项对每个事务中的数据进行排序,等价于 order by p[1] desc, p[0] descorderedItems = [v[0] for v in sorted(localD.items(), key=lambda p:(p[1],p[0]), reverse=True)]updateTree(orderedItems, myTree, headerTable, count)return myTree, headerTable

4、从FP树中获得条件模式基

#迭代上溯整棵树
def ascendTree(leafNode, prefixPath):if leafNode.parent != None:prefixPath.append(leafNode.name)ascendTree(leafNode.parent, prefixPath)
#遍历链表
def findPrefixPath(basePat, headerTable):condPats = {}treeNode = headerTable[basePat][1]while treeNode != None:prefixPath = []ascendTree(treeNode, prefixPath)if len(prefixPath) > 1:condPats[frozenset(prefixPath[1:])] = treeNode.counttreeNode = treeNode.nodeLinkreturn condPats

5、创造条件FP树

def mineTree(inTree, headerTable, minSup=1, preFix=set([]), freqItemList=[]):#排序minSup asc, value ascbigL = [v[0] for v in sorted(headerTable.items(), key=lambda p: (p[1][0],p[0]))]for basePat in bigL:newFreqSet = preFix.copy()newFreqSet.add(basePat)freqItemList.append(newFreqSet)# 通过条件模式基找到的频繁项集condPattBases = findPrefixPath(basePat, headerTable)myCondTree, myHead = createTree(condPattBases, minSup)if myHead != None:print('condPattBases: ', basePat, condPattBases)myCondTree.disp()print('*' * 30)mineTree(myCondTree, myHead, minSup, newFreqSet, freqItemList)

6、运行:

#初始化数据集
simpDat = loadSimpDat()
dictDat = createInitSet(simpDat)
freqItems=[] #存储频繁项集
#创建FP树,支持度设为3
myFPTree,myheader = createTree(dictDat, 3)
#创建条件FP树,支持度设为2
mineTree(myFPTree, myheader, 2 ,set([]),freqItems)
print('频繁项集为'+str(freqItems))

7、运行结果:

condPattBases:XXXX是频繁项的前缀路径,下面的是条件FP树。

三、参考资料

1、Harrington P , 李锐等. 机器学习实战[M]. 人民邮电出版社, 2013.

2、https://www.bilibili.com/video/av40754697 (推荐购买完整版)

3、https://blog.csdn.net/dq_dm/article/details/38111097

这篇关于Python数据挖掘学习笔记(7)频繁模式挖掘算法----FP-growth的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593599

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

如何开启和关闭3GB模式

https://jingyan.baidu.com/article/4d58d5414dfc2f9dd4e9c082.html

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

十四、观察者模式与访问者模式详解

21.观察者模式 21.1.课程目标 1、 掌握观察者模式和访问者模式的应用场景。 2、 掌握观察者模式在具体业务场景中的应用。 3、 了解访问者模式的双分派。 4、 观察者模式和访问者模式的优、缺点。 21.2.内容定位 1、 有 Swing开发经验的人群更容易理解观察者模式。 2、 访问者模式被称为最复杂的设计模式。 21.3.观察者模式 观 察 者 模 式 ( Obser