Canopy聚类是一种非常简单、快速、准确地把对象划分成聚类的方法。所有的对象都用多维特征空间中的一个点表示,此算法使用一种快速近似度量法,其两个距离阈值为T1>T2。
算法的基本思想是一开始有一个点集,先从其中选取一个点,并把此点移除此点集,接着创建一个包含此点的Canopy并对点集中剩余的点进行迭代,对于每一点,如果它与第一个点的距离小于T1,就把它添加到此Canopy中;如果它与第一个点的距离小于T2,先把此添加到Canopy中并把它从点集中删除。这种方式避免了对那些距中心点距离小于T2的点做进一步的处理。此算法不断地迭代直到初始点集为空为止,最终的结果是产生了一个Canopy的集合,每一个Canopy都包含了一个或多个点,每个点都可能出现在一个或多个Canopy中。Canopy集群经常用做更加严格的聚类技术(如k-Means聚类)的初始阶段。1)并行策略● 把数据转换为恰当的输入格式。● 每个mapper对输入集中的点执行Canopy聚类,并输出Canopy的中心。● reducer收集Canopy的中心,然后计算产生最终的Canopy中心。● 最后,将各个点划分到最终的Canopy中。2)设计实现此实现把包含多维点的序列文件作为Hadoop输入,点可用密集型矢量来表示,也可以用稀疏型矢量来表示。处理过程分为两个阶段,即Canopy生成阶段和聚类阶段(可选)。(1)Canopy生成阶段在Map阶段,每个mapper处理一个点的子集,并且使用已选的距离度量和阈值来产生Canopy。mapper根据已知的距离度量和阈值把各个点添加到Canopy中,接着产生此Canopy的中心即为输出,reducer收集所有的初始中心,然后再次应用距离度量和阈值来产生最终的Canopy中心的集合即为输出。reducer的输出格式为SequenceFile(Text,Canopy),关键字是Canopy标识符。(2)聚类阶段在聚类阶段中,每一个mapper都读取由第一阶段产生的Canopy作为输入,因为所有的mapper都由相同的Canopy定义,它们的输出都在shuffle阶段会产生合并,这样每一个reducer都会看到所有的点属于一个或多个Canopy。输出是SequenceFile(IntWritable, WeightedVectorWritable),关键字是CanopyId。WeightedVectorWritable有两个段,即一个double型的weight和一个VectorWritable的矢量,其表示了一个矢量属于一个给定Canopy的可能性。近年来,嵌入式系统的广泛应用已经深刻改变了我们的生活方式。从智能手机到智能家居,从汽车到医疗设备,嵌入式技术已经成为现代社会不可或缺的...详情>>
2023-12-12 11:02:35在当今的科技世界中,嵌入式系统已经渗透到我们生活的方方面面,从智能手机、电视、汽车到医疗设备等。而在这些设备中,Linux网络编程扮演着至...详情>>
2023-12-12 09:55:55在数字化世界中,游戏已经成为了人们休闲娱乐的重要方式之一。随着科技的不断进步,游戏开发行业也在不断发展,而Java作为一门广泛使用的编程语...详情>>
2023-12-12 08:49:15在数字化的时代,网页设计已经成为了一个重要的领域。而在这个领域中,HTML(HyperTextMarkupLanguage)无疑是最基础、最重要的一环。它是构建...详情>>
2023-12-12 08:15:55嵌入式系统开发中,内存分配是一个至关重要的话题。嵌入式系统通常具有有限的内存资源,因此合理的内存分配方式对系统的性能和稳定性至关重要。...详情>>
2023-12-12 06:35:55