- 1、本文档共42页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据挖掘课后作业
5.4(实现项目)使用你熟悉的程序设计语言(如C++或Java),实现本章介绍的三种频繁项集挖掘算法:(1)Apriori [AS94B],(2)FP增长[HPY00]和(3)ECLAT [Zak00](使用垂直数据格式挖掘)。在各种类型的大型数据集上比较每种算法的性能。写一个报告,分析在哪些情况下(如数据大小、数据分布、最小支持阀度值设置和模式的稠密度),某种算法比其他算法好,并陈述理由。项集较大,频繁项集较分散,是一个稀疏型的数据集数据集的项集较小,数据非常稠密各算法采用的数据表示模式及挖掘策略不同。采用优化措施后的 Apriori算法,对于非稠密数据己经具有较高的效率,其性能甚至优于FP-growth 算法;但由于其采用的是广度优先的挖掘策略,对稠密数据效率仍较差。而 Eclat 算法采用的纵向表示法,对数据集较小的稠密数据,效率相对较高;但对于数据集较大的稀疏数据,效率较低,FP一树浓缩了数据库的主要信息,分而治之的挖掘策略也使挖掘问题的复杂程度有所降低。答:(1)Apriori算法的实现:使用Java语言实现Apriori算法,AprioriAlgorithm类包含了频繁项集的挖掘过程和频繁关联规则的挖掘过程;ProperSubsetCombination辅助类用于计算一个频繁项集的真子集,采用组合原理,基于数值编码原理实现的组合求解集合的真子集。
Apriori算法的核心实现类为AprioriAlgorithm,实现的Java代码如下所示:
(一)核心类
package org.shirdrn.datamining.association;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
/**
* B关联规则挖掘:Apriori算法/B
*
* P该算法基本上按照Apriori算法的基本思想来实现的。
*/
public class AprioriAlgorithm {
private MapInteger, SetString txDatabase; // 事务数据库
private Float minSup; // 最小支持度
private Float minConf; // 最小置信度
private Integer txDatabaseCount; // 事务数据库中的事务数
private MapInteger, SetSetString freqItemSet; // 频繁项集集合
private MapSetString, SetSetString assiciationRules; // 频繁关联规则集合
public AprioriAlgorithm(
??? MapInteger, SetString txDatabase,
??? Float minSup,
??? Float minConf) {
?? this.txDatabase = txDatabase;
?? this.minSup = minSup;
?? this.minConf = minConf;
?? this.txDatabaseCount = this.txDatabase.size();
?? freqItemSet = new TreeMapInteger, SetSetString();
?? assiciationRules = new HashMapSetString, SetSetString();
}
/**
* 扫描事务数据库,计算频繁1-项集
* @return
*/
public MapSetString, Float getFreq1ItemSet() {
?? MapSetString, Float freq1ItemSetMap = new HashMapSetString, Float();
?? MapSetString, Integer candFreq1ItemSet = this.getCandFreq1ItemSet();
?? IteratorMap.EntrySetString, Integer it = candFreq1ItemSet.entrySet().iterator();
?? while(it.hasNext()) {
??? Map.EntrySetString, Integer entry = it.next();
??? // 计算支持度
??? Float supported = n
文档评论(0)