python實(shí)現(xiàn)密度聚類(模板代碼+sklearn代碼)
本人在此就不搬運(yùn)書上關(guān)于密度聚類的理論知識(shí)了,僅僅實(shí)現(xiàn)密度聚類的模板代碼和調(diào)用skelarn的密度聚類算法。
有人好奇,為什么有sklearn庫了還要自己去實(shí)現(xiàn)呢?其實(shí),庫的代碼是比自己寫的高效且容易,但自己實(shí)現(xiàn)代碼會(huì)對(duì)自己對(duì)算法的理解更上一層樓。
#調(diào)用科學(xué)計(jì)算包與繪圖包 import numpy as np import random import matplotlib.pyplot as plt
# 獲取數(shù)據(jù) def loadDataSet(filename): dataSet=np.loadtxt(filename,dtype=np.float32,delimiter=',') return dataSet
#計(jì)算兩個(gè)向量之間的歐式距離
def calDist(X1 , X2 ):
sum = 0
for x1 , x2 in zip(X1 , X2):
sum += (x1 - x2) ** 2
return sum ** 0.5
#獲取一個(gè)點(diǎn)的ε-鄰域(記錄的是索引)
def getNeibor(data , dataSet , e):
res = []
for i in range(dataSet.shape[0]):
if calDist(data , dataSet[i])<e:
res.append(i)
return res
#密度聚類算法
def DBSCAN(dataSet , e , minPts):
coreObjs = {}#初始化核心對(duì)象集合
C = {}
n = dataSet.shape[0]
#找出所有核心對(duì)象,key是核心對(duì)象的index,value是ε-鄰域中對(duì)象的index
for i in range(n):
neibor = getNeibor(dataSet[i] , dataSet , e)
if len(neibor)>=minPts:
coreObjs[i] = neibor
oldCoreObjs = coreObjs.copy()
k = 0#初始化聚類簇?cái)?shù)
notAccess = list(range(n))#初始化未訪問樣本集合(索引)
while len(coreObjs)>0:
OldNotAccess = []
OldNotAccess.extend(notAccess)
cores = coreObjs.keys()
#隨機(jī)選取一個(gè)核心對(duì)象
randNum = random.randint(0,len(cores)-1)
cores=list(cores)
core = cores[randNum]
queue = []
queue.append(core)
notAccess.remove(core)
while len(queue)>0:
q = queue[0]
del queue[0]
if q in oldCoreObjs.keys() :
delte = [val for val in oldCoreObjs[q] if val in notAccess]#Δ = N(q)∩Γ
queue.extend(delte)#將Δ中的樣本加入隊(duì)列Q
notAccess = [val for val in notAccess if val not in delte]#Γ = Γ\Δ
k += 1
C[k] = [val for val in OldNotAccess if val not in notAccess]
for x in C[k]:
if x in coreObjs.keys():
del coreObjs[x]
return C
# 代碼入口 dataSet = loadDataSet(r"E:\jupyter\sklearn學(xué)習(xí)\sklearn聚類\DataSet.txt") print(dataSet) print(dataSet.shape) C = DBSCAN(dataSet, 0.11, 5) draw(C, dataSet)
結(jié)果圖:

下面是調(diào)用sklearn庫的實(shí)現(xiàn)
db = skc.DBSCAN(eps=1.5, min_samples=3).fit(dataSet) #DBSCAN聚類方法 還有參數(shù),matric = ""距離計(jì)算方法
labels = db.labels_ #和X同一個(gè)維度,labels對(duì)應(yīng)索引序號(hào)的值 為她所在簇的序號(hào)。若簇編號(hào)為-1,表示為噪聲
print('每個(gè)樣本的簇標(biāo)號(hào):')
print(labels)
raito = len(labels[labels[:] == -1]) / len(labels) #計(jì)算噪聲點(diǎn)個(gè)數(shù)占總數(shù)的比例
print('噪聲比:', format(raito, '.2%'))
n_clusters_ = len(set(labels)) - (1 if -1 in labels else 0) # 獲取分簇的數(shù)目
print('分簇的數(shù)目: %d' % n_clusters_)
print("輪廓系數(shù): %0.3f" % metrics.silhouette_score(X, labels)) #輪廓系數(shù)評(píng)價(jià)聚類的好壞
for i in range(n_clusters_):
print('簇 ', i, '的所有樣本:')
one_cluster = X[labels == i]
print(one_cluster)
plt.plot(one_cluster[:,0],one_cluster[:,1],'o')
plt.show()
到此這篇關(guān)于python實(shí)現(xiàn)密度聚類(模板代碼+sklearn代碼)的文章就介紹到這了,更多相關(guān)python 密度聚類內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python數(shù)據(jù)分析之用sklearn預(yù)測糖尿病
- Python之Sklearn使用入門教程
- 運(yùn)行python提示no module named sklearn的解決方法
- python安裝sklearn模塊的方法詳解
- python3.6中anaconda安裝sklearn踩坑實(shí)錄
- Python sklearn中的.fit與.predict的用法說明
- python實(shí)點(diǎn)云分割k-means(sklearn)詳解
- python中sklearn的pipeline模塊實(shí)例詳解
- python sklearn包——混淆矩陣、分類報(bào)告等自動(dòng)生成方式
- Python sklearn庫實(shí)現(xiàn)PCA教程(以鳶尾花分類為例)
- Python 機(jī)器學(xué)習(xí)工具包SKlearn的安裝與使用
相關(guān)文章
python3實(shí)現(xiàn)讀取chrome瀏覽器cookie
這里給大家分享的是python3讀取chrome瀏覽器的cookie(CryptUnprotectData解密)的代碼,主要思路是讀取到的cookies被封裝成字典,可以直接給requests使用。2016-06-06
Python的bit_length函數(shù)來二進(jìn)制的位數(shù)方法
今天小編就為大家分享一篇Python的bit_length函數(shù)來二進(jìn)制的位數(shù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08
itchat和matplotlib的結(jié)合使用爬取微信信息的實(shí)例
下面小編就為大家?guī)硪黄猧tchat和matplotlib的結(jié)合使用爬取微信信息的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
pip安裝指定版本的tensorflow的實(shí)現(xiàn)
本文介紹了如何使用pip安裝指定版本的TensorFlow,包括CPU版本和GPU版本的安裝方法,同時(shí),文中也提到了使用阿里國內(nèi)鏡像源加速下載的方法,以及在安裝GPU版本時(shí)需要檢查CUDA和cuDNN的兼容性的注意事項(xiàng),感興趣的可以了解一下2024-10-10
Python標(biāo)準(zhǔn)庫pickle的簡單使用
本文主要介紹了Python標(biāo)準(zhǔn)庫pickle的簡單使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
Phantomjs抓取渲染JS后的網(wǎng)頁(Python代碼)
phantomjs:我的理解就是它是一個(gè)無顯示的瀏覽器,也就是說除了不能顯示頁面內(nèi)容以外,瀏覽器能干的活兒它基本上都能干。下面我們就來利用他做點(diǎn)有趣的事情2016-05-05
Python高級(jí)架構(gòu)模式知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理了一篇關(guān)于Python高級(jí)架構(gòu)模式知識(shí)點(diǎn)總結(jié)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。2021-08-08

