千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Canopy聚類

Canopy聚類

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-12-04 08:07:26 1701648446

Canopy聚類是一種非常簡單、快速、準(zhǔn)確地把對象劃分成聚類的方法。所有的對象都用多維特征空間中的一個點(diǎn)表示,此算法使用一種快速近似度量法,其兩個距離閾值為T1>T2。

算法的基本思想是一開始有一個點(diǎn)集,先從其中選取一個點(diǎn),并把此點(diǎn)移除此點(diǎn)集,接著創(chuàng)建一個包含此點(diǎn)的Canopy并對點(diǎn)集中剩余的點(diǎn)進(jìn)行迭代,對于每一點(diǎn),如果它與第一個點(diǎn)的距離小于T1,就把它添加到此Canopy中;如果它與第一個點(diǎn)的距離小于T2,先把此添加到Canopy中并把它從點(diǎn)集中刪除。這種方式避免了對那些距中心點(diǎn)距離小于T2的點(diǎn)做進(jìn)一步的處理。

此算法不斷地迭代直到初始點(diǎn)集為空為止,最終的結(jié)果是產(chǎn)生了一個Canopy的集合,每一個Canopy都包含了一個或多個點(diǎn),每個點(diǎn)都可能出現(xiàn)在一個或多個Canopy中。Canopy集群經(jīng)常用做更加嚴(yán)格的聚類技術(shù)(如k-Means聚類)的初始階段。

1)并行策略

● 把數(shù)據(jù)轉(zhuǎn)換為恰當(dāng)?shù)妮斎敫袷健?/p>

● 每個mapper對輸入集中的點(diǎn)執(zhí)行Canopy聚類,并輸出Canopy的中心。

● reducer收集Canopy的中心,然后計算產(chǎn)生最終的Canopy中心。

● 最后,將各個點(diǎn)劃分到最終的Canopy中。

2)設(shè)計實(shí)現(xiàn)

此實(shí)現(xiàn)把包含多維點(diǎn)的序列文件作為Hadoop輸入,點(diǎn)可用密集型矢量來表示,也可以用稀疏型矢量來表示。處理過程分為兩個階段,即Canopy生成階段和聚類階段(可選)。

(1)Canopy生成階段

在Map階段,每個mapper處理一個點(diǎn)的子集,并且使用已選的距離度量和閾值來產(chǎn)生Canopy。mapper根據(jù)已知的距離度量和閾值把各個點(diǎn)添加到Canopy中,接著產(chǎn)生此Canopy的中心即為輸出,reducer收集所有的初始中心,然后再次應(yīng)用距離度量和閾值來產(chǎn)生最終的Canopy中心的集合即為輸出。reducer的輸出格式為SequenceFile(Text,Canopy),關(guān)鍵字是Canopy標(biāo)識符。

(2)聚類階段

在聚類階段中,每一個mapper都讀取由第一階段產(chǎn)生的Canopy作為輸入,因?yàn)樗械膍apper都由相同的Canopy定義,它們的輸出都在shuffle階段會產(chǎn)生合并,這樣每一個reducer都會看到所有的點(diǎn)屬于一個或多個Canopy。輸出是SequenceFile(IntWritable, WeightedVectorWritable),關(guān)鍵字是CanopyId。WeightedVectorWritable有兩個段,即一個double型的weight和一個VectorWritable的矢量,其表示了一個矢量屬于一個給定Canopy的可能性。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取

上一篇

k-Means聚類

下一篇

mahout分類算法
相關(guān)推薦HOT
嵌入式培訓(xùn)課程:探索技術(shù)的無限可能

近年來,嵌入式系統(tǒng)的廣泛應(yīng)用已經(jīng)深刻改變了我們的生活方式。從智能手機(jī)到智能家居,從汽車到醫(yī)療設(shè)備,嵌入式技術(shù)已經(jīng)成為現(xiàn)代社會不可或缺的...詳情>>

2023-12-12 11:02:35
嵌入式開發(fā):Linux網(wǎng)絡(luò)編程的探索與實(shí)踐

在當(dāng)今的科技世界中,嵌入式系統(tǒng)已經(jīng)滲透到我們生活的方方面面,從智能手機(jī)、電視、汽車到醫(yī)療設(shè)備等。而在這些設(shè)備中,Linux網(wǎng)絡(luò)編程扮演著至...詳情>>

2023-12-12 09:55:55
Java游戲項(xiàng)目開發(fā):技術(shù)概覽與實(shí)踐

在數(shù)字化世界中,游戲已經(jīng)成為了人們休閑娛樂的重要方式之一。隨著科技的不斷進(jìn)步,游戲開發(fā)行業(yè)也在不斷發(fā)展,而Java作為一門廣泛使用的編程語...詳情>>

2023-12-12 08:49:15
Web前端的基石:HTML

在數(shù)字化的時代,網(wǎng)頁設(shè)計已經(jīng)成為了一個重要的領(lǐng)域。而在這個領(lǐng)域中,HTML(HyperTextMarkupLanguage)無疑是最基礎(chǔ)、最重要的一環(huán)。它是構(gòu)建...詳情>>

2023-12-12 08:15:55
嵌入式開發(fā):內(nèi)存分配的方式

嵌入式系統(tǒng)開發(fā)中,內(nèi)存分配是一個至關(guān)重要的話題。嵌入式系統(tǒng)通常具有有限的內(nèi)存資源,因此合理的內(nèi)存分配方式對系統(tǒng)的性能和穩(wěn)定性至關(guān)重要。...詳情>>

2023-12-12 06:35:55
快速通道