色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

k-means算法原理解析

倩倩 ? 來源:網絡整理 ? 2018-02-12 16:06 ? 次閱讀

K-MEANS算法

K-MEANS算法是輸入聚類個數k,以及包含 n個數據對象的數據庫,輸出滿足方差最小標準k個聚類的一種算法。k-means 算法接受輸入量 k ;然后將n個數據對象劃分為 k個聚類以便使得所獲得的聚類滿足:同一聚類中的對象相似度較高;而不同聚類中的對象相似度較小。

聚類相似度是利用各聚類中對象的均值所獲得一個“中心對象”(引力中心)來進行計算的。

K-Means聚類算法原理

K-Means算法是無監督的聚類算法,它實現起來比較簡單,聚類效果也不錯,因此應用很廣泛。K-Means算法有大量的變體,本文就從最傳統的K-Means算法講起,在其基礎上講述K-Means的優化變體方法。包括初始化優化K-Means++, 距離計算優化elkan K-Means算法和大數據情況下的優化Mini Batch K-Means算法。

1. K-Means原理初探

K-Means算法的思想很簡單,對于給定的樣本集,按照樣本之間的距離大小,將樣本集劃分為K個簇。讓簇內的點盡量緊密的連在一起,而讓簇間的距離盡量的大。

如果用數據表達式表示,假設簇劃分之間的隨機數為(C1,C2,。。.Ck),則我們的目標是最小化平方誤差E:

E=∑i=1k∑x∈Ci||x?μi||22E=∑i=1k∑x∈Ci||x?μi||22

其中μi是簇Ci的均值向量,有時也稱為質心,表達式為:

μi=1|Ci|∑x∈Cixμi=1|Ci|∑x∈Cix

如果我們想直接求上式的最小值并不容易,這是一個NP難的問題,因此只能采用啟發式的迭代方法。K-Means采用的啟發式方式很簡單,用下面一組圖就可以形象的描述。

k-means算法原理解析

上圖a表達了初始的數據集,假設k=2。在圖b中,我們隨機選擇了兩個k類所對應的類別質心,即圖中的紅色質心和藍色質心,然后分別求樣本中所有點到這兩個質心的距離,并標記每個樣本的類別為和該樣本距離最小的質心的類別,如圖c所示,經過計算樣本和紅色質心和藍色質心的距離,我們得到了所有樣本點的第一輪迭代后的類別。此時我們對我們當前標記為紅色和藍色的點分別求其新的質心,如圖4所示,新的紅色質心和藍色質心的位置已經發生了變動。圖e和圖f重復了我們在圖c和圖d的過程,即將所有點的類別標記為距離最近的質心的類別并求新的質心。最終我們得到的兩個類別如圖f。當然在實際K-Mean算法中,我們一般會多次運行圖c和圖d,才能達到最終的比較優的類別。

讀者可以通過下面這個動態圖來形象的了解算法的實現過程

在上一節我們對K-Means的原理做了初步的探討,這里我們對K-Means的算法做一個總結。

首先我們看看K-Means算法的一些要點。

1)對于K-Means算法,首先要注意的是k值的選擇,一般來說,我們會根據對數據的先驗經驗選擇一個合適的k值,如果沒有什么先驗知識,則可以通過交叉驗證選擇一個合適的k值。

2)在確定了k的個數后,我們需要選擇k個初始化的質心,就像上圖b中的隨機質心。由于我們是啟發式方法,k個初始化的質心的位置選擇對最后的聚類結果和運行時間都有很大的影響,因此需要選擇合適的k個質心,最好這些質心不能太近。

好了,現在我們來總結下傳統的K-Means算法流程。

輸入是樣本集D={x1,x2,。..xm}D={x1,x2,。..xm},聚類的簇樹k,最大迭代次數N

輸出是簇劃分C={C1,C2,。..Ck}C={C1,C2,。..Ck}

1) 從數據集D中隨機選擇k個樣本作為初始的k個質心向量: {μ1,μ2,。..,μk}{μ1,μ2,。..,μk}

2)對于n=1,2,。..,N

a) 將簇劃分C初始化為Ct=?t=1,2.。.kCt=?t=1,2.。.k

b) 對于i=1,2.。.m,計算樣本xixi和各個質心向量μj(j=1,2,。..k)μj(j=1,2,。..k)的距離:dij=||xi?μj||22dij=||xi?μj||22,將xixi標記最小的為dijdij所對應的類別λiλi。此時更新Cλi=Cλi∪{xi}Cλi=Cλi∪{xi}

c) 對于j=1,2,。..,k,對CjCj中所有的樣本點重新計算新的質心μj=1|Cj|∑x∈Cjxμj=1|Cj|∑x∈Cjx

e) 如果所有的k個質心向量都沒有發生變化,則轉到步驟3)

3) 輸出簇劃分C={C1,C2,。..Ck}C={C1,C2,。..Ck}

3. K-Means初始化優化K-Means++

在上節我們提到,k個初始化的質心的位置選擇對最后的聚類結果和運行時間都有很大的影響,因此需要選擇合適的k個質心。如果僅僅是完全隨機的選擇,有可能導致算法收斂很慢。K-Means++算法就是對K-Means隨機初始化質心的方法的優化。

關于這里,原作者博客寫的有點兒含糊,網上有幾篇博客寫的不是很清楚,這里把他們總結在一起,特別對有問題的地方用紅色字體解釋和說明:

k-means++算法選擇初始seeds的基本思想就是:初始的聚類中心之間的相互距離要盡可能的遠。wiki上對該算法的描述是如下:

1,從輸入的數據點集合中隨機選擇一個點作為第一個聚類中心

2,對于數據集中的每一個點x,計算它與最近聚類中心(指已選擇的聚類中心)的距離D(x)

3,選擇一個新的數據點作為新的聚類中心,選擇的原則是:D(x)較大的點,被選取作為聚類中心的概率較大

4,重復2和3直到k個聚類中心被選出來

5,利用這k個初始的聚類中心來運行標準的k-means算法

從上面的算法描述上可以看到,算法的關鍵是第3步,如何將D(x)反映到點被選擇的概率上,一種算法如下:

1,先從我們的數據庫隨機挑個隨機點當“種子點”

2,對于每個點,我們都計算其和最近的一個“種子點”的距離D(x)并保存在一個數組里,然后把這些距離加起來得到Sum(D(x))。

3,然后,再取一個隨機值,用權重的方式來取下一個“種子點”。

這個算法的實現是:先取一個能落在Sum(D(x))中的隨機值Random,然后用Random -= D(x),直到,Random《=0(注意,這個式子的意思是:在剛才保存的那個數組里,我們從頭開始遍歷每一個元素的D(x),直到減掉的Random小于0,此時停止),此時的點就是下一個“種子點”。

4,重復2和3直到k個聚類中心被選出來

5,利用這k個初始的聚類中心來運行標準的k-means算法

可以看到算法的第三步選取新中心的方法,這樣就能保證距離D(x)較大的點,會被選出來作為聚類中心了。至于為什么原因很簡單,如下圖 所示:

假設A、B、C、D的D(x)如上圖所示,當算法取值Sum(D(x))*random(原作者博客里這樣寫是因為在編程語言中,random函數產生的是0-1之間的 隨機數,所以他用Sum(D(x))*random來表示隨機生成一個位于[0-Sum(D(x))]之間的隨機數),該值會以較大的概率落入D(x)較大的區間內,所以對應的點會以較大的概率被選中作為新的聚類中心。

4. K-Means距離計算優化elkan K-Means

在傳統的K-Means算法中,我們在每輪迭代時,要計算所有的樣本點到所有的質心的距離,這樣會比較的耗時。那么,對于距離的計算有沒有能夠簡化的地方呢?elkan K-Means算法就是從這塊入手加以改進。它的目標是減少不必要的距離的計算。那么哪些距離不需要計算呢?elkan K-Means利用了兩邊之和大于等于第三邊,以及兩邊之差小于第三邊的三角形性質,來減少距離的計算。

第一種規律是對于一個樣本點x和兩個質心μj1,μj2。如果我們預先計算出了這兩個質心之間的距離D(j1,j2),則如果計算發現2D(x,j1)≤D(j1,j2),我們立即就可以知道

D(x,j1)≤D(x,j2)。此時我們不需要再計算D(x,j2),也就是說省了一步距離計算。

第二種規律是對于一個樣本點xx和兩個質心μj1,μj2。我們可以得到D(x,j2)≥max{0,D(x,j1)?D(j1,j2)}這個從三角形的性質也很容易得到。

利用上邊的兩個規律,elkan K-Means比起傳統的K-Means迭代速度有很大的提高。但是如果我們的樣本的特征是稀疏的,有缺失值的話,這個方法就不使用了,此時某些距離無法計算,則不能使用該算法。

5. 大樣本優化Mini Batch K-Means

在傳統的K-Means算法中,要計算所有的樣本點到所有的質心的距離。如果樣本量非常大,比如達到10萬以上,特征有100以上,此時用傳統的K-Means算法非常的耗時,就算加上elkan K-Means優化也依舊。在大數據時代,這樣的場景越來越多。此時Mini Batch K-Means應運而生。

顧名思義,Mini Batch,也就是用樣本集中的一部分的樣本來做傳統的K-Means,這樣可以避免樣本量太大時的計算難題,算法收斂速度大大加快。當然此時的代價就是我們的聚類的精確度也會有一些降低。一般來說這個降低的幅度在可以接受的范圍之內。

在Mini Batch K-Means中,我們會選擇一個合適的批樣本大小batch size,我們僅僅用batch size個樣本來做K-Means聚類。那么這batch size個樣本怎么來的?一般是通過無放回的隨機采樣得到的。

為了增加算法的準確性,我們一般會多跑幾次Mini Batch K-Means算法,用得到不同的隨機采樣集來得到聚類簇,選擇其中最優的聚類簇。

6. K-Means(K-近鄰學習)與KNN(k-近鄰估計)

初學者很容易把K-Means和KNN搞混,兩者其實差別還是很大的。

K-Means是無監督學習的聚類算法,沒有樣本輸出;而KNN是監督學習的分類算法,有對應的類別輸出。KNN基本不需要訓練,對測試集里面的點,只需要找到在訓練集中最近的k個點,用這最近的k個點的類別來決定測試點的類別。而K-Means則有明顯的訓練過程,找到k個類別的最佳質心,從而決定樣本的簇類別。

當然,兩者也有一些相似點,兩個算法都包含一個過程,即找出和某一個點最近的點。兩者都利用了最近鄰(nearest neighbors)的思想。

7. K-Means小結

K-Means是個簡單實用的聚類算法,這里對K-Means的優缺點做一個總結。

K-Means的主要優點有:

1)原理比較簡單,實現也是很容易,收斂速度快。

2)聚類效果較優。

3)算法的可解釋度比較強。

4)主要需要調參的參數僅僅是簇數k。

K-Means的主要缺點有:

1)K值的選取不好把握

2)對于不是凸的數據集比較難收斂

3)如果各隱含類別的數據不平衡,比如各隱含類別的數據量嚴重失衡,或者各隱含類別的方差不同,則聚類效果不佳。

4) 采用迭代方法,得到的結果只是局部最優。

5) 對噪音和異常點比較的敏感。

k-means聚類算法的應用

聚類就是按照一定的標準將事物進行區分和分類的過程,該過程是無監督的,即事先并不知道關于類分的任何知識。聚類分析又稱為數據分割,它是指應用數學的方法研究和處理給定對象的分類,使得每個組內部對象之間的相關性比其他對象之間的相關性高,組間的相異性較高。

聚類算法被用于許多知識領域,這些領域通常要求找出特定數據中的“自然關聯”。自然關聯的定義取決于不同的領域和特定的應用,可以具有多種形式。典型的應用例如:

1. 商務上,幫助市場分析人員從客戶基本資料庫中發現不同的客戶群,并用購買模式來刻畫不同客戶群的特征;

2. 聚類分析是細分市場的有效工具,同時也可用于研究消費者行為,尋找新的潛在市場、選擇實驗的市場,并作為多元分析的預處理。

3. 生物學上,用于推導植物和動物的分類,對基因進行分類,獲得對種群固有結構的認識;

4. 地理信息方面,在地球觀測數據庫中相似區域的確定、汽車保險單持有者的分組,及根據房子的類型、價值和地理位置對一個城市中房屋的分組上可以發揮作用;

5. 聚類也能用于在網上進行文檔歸類來修復信息;

6. 在電子商務網站建設數據挖掘中的應用,通過分組聚類出具有相似瀏覽行為的客戶,并分析客戶的共同特征,可以更好的幫助電子商務的用戶了解自己的客戶,向客戶提供更合適的服務。

7. 聚類分析可以作為其它數據挖掘算法的預處理步驟,便于這些算法在生成的簇上進行處理。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • K-means
    +關注

    關注

    0

    文章

    28

    瀏覽量

    11293
  • k-means算法
    +關注

    關注

    0

    文章

    1

    瀏覽量

    1774
收藏 人收藏

    評論

    相關推薦

    使用K-means壓縮圖像

    山東大學機器學習(實驗六內容)—— K-Means
    發表于 08-28 09:25

    調用sklearn使用的k-means模型

    【python】調用sklearn使用k-means模型
    發表于 06-12 13:33

    K-Means有什么優缺點?

    K-Means的主要優點是什么?K-Means的主要缺點是什么?
    發表于 06-10 06:14

    改進的k-means聚類算法在供電企業CRM中的應用

    針對k-means算法存在的不足,提出了一種改進算法。 針對目前供電企業CRM系統的特點提出了用聚類分析方法進行客戶群細分模型設計,通過實驗驗證了本文提出的k-means改進
    發表于 03-01 15:28 ?15次下載

    Web文檔聚類中k-means算法的改進

    Web文檔聚類中k-means算法的改進 介紹了Web文檔聚類中普遍使用的、基于分割的k-means算法,分析了k-means
    發表于 09-19 09:17 ?1054次閱讀
    Web文檔聚類中<b class='flag-5'>k-means</b><b class='flag-5'>算法</b>的改進

    K-means+聚類算法研究綜述

    介紹了K-means 聚類算法的目標函數、算法流程,并列舉了一個實例,指出了數據子集的數目K、初始聚類中心選取、相似性度量和距離矩陣為K-means
    發表于 05-07 14:09 ?27次下載
    <b class='flag-5'>K-means</b>+聚類<b class='flag-5'>算法</b>研究綜述

    基于密度的K-means算法在聚類數目中應用

    針對傳統的K-means算法無法預先明確聚類數目,對初始聚類中心選取敏感且易受離群孤點影響導致聚類結果穩定性和準確性欠佳的問題,提出一種改進的基于密度的K-means算法。該
    發表于 11-25 11:35 ?0次下載

    K-Means算法改進及優化

    傳統的k-means算法采用的是隨機數初始化聚類中心的方法,這種方法的主要優點是能夠快速的產生初始化的聚類中心,其主要缺點是初始化的聚類中心可能會同時出現在同一個類別中,導致迭代次數過多,甚至陷入
    發表于 12-05 18:32 ?0次下載
    <b class='flag-5'>K-Means</b><b class='flag-5'>算法</b>改進及優化

    基于布谷鳥搜索的K-means聚類算法

    針對原始K-means聚類算法受初始聚類中心影響過大以及容易陷入局部最優的不足,提出一種基于改進布谷鳥搜索(cs)的K-means聚類算法(ACS-
    發表于 12-13 17:24 ?3次下載

    熵加權多視角核K-means算法

    在基于視角加權的多視角聚類中,每個視角的權重取值對聚類結果的精度都有著重要的影V向。針對此問題,提出熵加權多視角核K-means( EWKKM)算法,通過給每個視角分配一個合理的權值來降低噪聲視角或
    發表于 12-17 09:57 ?1次下載

    K-Means算法的簡單介紹

    K-Means是十大經典數據挖掘算法之一。K-Means和KNN(K鄰近)看上去都是K打頭,但卻是不同種類的
    發表于 07-05 14:18 ?4915次閱讀

    如何使用K-Means聚類算法改進的特征加權算法詳細資料概述

    聚類分析是將研究對象分為相對同質的群組的統計分析技術,聚類分析的核心就是發現有用的對象簇。K-means聚類算法由于具有出色的速度和良好的可擴展性,一直備受廣大學者的關注。然而,傳統的K-means
    發表于 12-20 10:28 ?10次下載

    K-MEANS聚類算法概述及工作原理

    K-means 是一種聚類算法,且對于數據科學家而言,是簡單且熱門的無監督式機器學習(ML)算法之一。
    的頭像 發表于 06-06 11:53 ?3987次閱讀

    K-means聚類算法指南

    在聚類技術領域中,K-means可能是最常見和經常使用的技術之一。K-means使用迭代細化方法,基于用戶定義的集群數量(由變量K表示)和數據集來產生其最終聚類。例如,如果將K設置為3
    的頭像 發表于 10-28 14:25 ?1459次閱讀

    大學課程 數據分析 實戰之K-means算法(2)算法代碼

    繼續講解! 程序來啦! 最后看一下程序示例!看看如何用K-means算法實現數據聚類的過程。程序很簡單,側重讓大家了解和掌握 K-means算法 聚類的過程! 看代碼吧!程序由三部
    的頭像 發表于 02-11 07:20 ?448次閱讀
    主站蜘蛛池模板: 明星三级电影| 韩国演艺圈qvod| 国产精品久久久久秋霞影视| 同时被两个男人轮流舔| 国精产品一区二区三区| 成人免费看片45分钟| 欧美日韩精品一区二区三区四区 | 亚洲国产中文在线视频免费| 国产 欧美 亚洲 日韩视频| 欧美性色xo影院69| 强奷表妺好紧2| 冰山高冷受被c到哭np双性| 免费视频久久只有精品| 99久久久无码国产AAA精品| 日本19xxxx撤尿| 动漫美女被到爽了流| 翁止熄痒禁伦短文合集免费视频| 国产成人免费| 亚洲精品国偷拍自产在线| 久久99热在线观看7| 2019午夜福合集不打码| 欧美成人momandson| 成人小视频在线观看免费| 她也色在线视频站| 国产亚洲精品视频亚洲香蕉视| 亚洲欧美国产综合在线一区| 久久精品国产久精国产果冻传媒| 2019天天射干网站| 日产国产欧美韩国在线| 国产精品亚洲专区在线播放| 亚洲一区在线观看无码欧美| 久久午夜免费视频| qvod伦理片| 亚洲AV久久无码精品蜜桃| 久久www免费人成_看片高清| bbwvideoa欧美老妇| 无码人妻精品国产婷婷| 精品一品国产午夜福利视频| 99久久99久久精品| 手机看片国产免费| 久久99国产精品自在自在|