摘要:如何確定最佳的值類別數本文選取手肘法手肘法對于每一個值,計算它的誤差平方和其中是點的個數,是第個點,是對應的中心。隨著聚類數的增大,樣本劃分會更加精細,每個簇的聚合程度會逐漸提高,那么誤差平方和自然會逐漸變小。
目錄
?手肘法:K-means聚類最優k值的選取_qq_15738501的博客-CSDN博客_kmeans聚類k的選取
matplotlib.pyplot.scatter散點圖的畫法:
將物理或抽象對象的集合分成由類似的對象組成的多個類的過程被稱為聚類。由聚類所生成的簇是一組數據對象的集合,這些對象與同一個簇中的對象彼此相似,與其他簇中的對象相異。
?kmeans算法又名k均值算法,K-means算法中的k表示的是聚類為k個簇,means代表取每一個聚類中數據值的均值作為該簇的中心,或者稱為質心,即用每一個的類的質心對該簇進行描述。
歐式距離:
曼哈頓距離:
余弦相似度:
????????A與B表示向量(x1,y1),(x2,y2)
????????分子為A與B的點乘,分母為二者各自的L2相乘,即將所有維度值的平方相加后開方。
本文選取手肘法
對于每一個k值,計算它的誤差平方和(SSE):
?其中N是點的個數,Xi?是第i 個點,ci 是Xi 對應的中心。
import numpy as npimport matplotlib.pyplot as pltimport mathk = eval(input("請輸入想要劃分的類別個數")) #規定類別數n = eval(input("請輸入要循環的次數"))#規定循環次數sw = eval(input("請輸入想要查詢的元素在數據中的位置"))def readdata():#獲取data數據中坐標值 data = np.loadtxt("E://Python//Lab4//Lab4.dat")#讀取dat數據 x_data = data[:,0]#橫坐標 y_data = data[:,1]#縱坐標 return data,x_data,y_datadef init(k):#初始化生成k個隨機類別中心 data,x_data,y_data = readdata() class_center = [] for i in range(k): #在數據的最大值與最小值間給出隨機值 x = np.random.randint(np.min(x_data),np.max(x_data)) y = np.random.randint(np.min(y_data),np.max(y_data)) class_center.append(np.array([x,y]))#以數組方式添加,方便后面計算距離 return class_centerdef dist(a,b):#計算兩個坐標間的歐氏距離 dist = math.sqrt(math.pow((a[0] - b[0]),2) + math.pow((a[1] - b[1]),2)) return distdef dist_rank(center,data):#得到與類中心最小距離的類別位置索引 tem = [] for m in range(k): d = dist(data, center[m]) tem.append(d) loc = tem.index(min(tem)) return locdef means(arr):#計算類的平均值當作類的新中心 sum_x,sum_y =0,0 for n in arr: sum_x += n[0] sum_y += n[1] mean_x = sum_x / len(arr) mean_y = sum_y / len(arr) return [mean_x,mean_y]def divide(center,data):#將每一個二維坐標分到與之歐式距離最近的類里 cla_arr = [[]] for i in range(k-1):#創建與k值相同維度的空數組存取坐標 cla_arr.append([]) for j in range(len(data)): loc = dist_rank(center,data[j]) cla_arr[loc].append(list(data[j])) return cla_arrdef new_center(cla):#計算每類平均值更新類中心 new_cen = [] for g in range(k): new = means(cla[g]) new_cen.append(new) return new_cendef index_element(arr,data,sw):#索引第sw個元素對應的類別 index = [] for i in range(len(data)):#遍歷每一個數據 for j in range(k):#遍歷每一個類別 tem = arr[j] for d in range(len(tem)):#遍歷類別內的每一個數據 if data[i][0] == tem[d][0] and data[i][1] == tem[d][1]:#如果橫縱坐標數值都相等 index.append((j + 1))#歸為j+1類 else: continue return index[sw]def Kmeans(n,sw):#獲取n次更新后類別中心以及第sw個元素對應的類別 data, x_data, y_data = readdata()#讀取數據 center = init(k) # 獲取初始類別中心 while n > 0: cla_arr = divide(center,data)# 將數據分到隨機選取的類中心的里 center = new_center(cla_arr)#更新類別中心 n -= 1 sse1 = 0 for j in range(k): for i in range(len(cla_arr[j])): # 計算每個類里的誤差平方 # 計算每個類里每個元素與元素中心的誤差平方 dist1 = math.pow(dist(cla_arr[j][i], center[j]), 2) sse1 += dist1 sse1 = sse1 / len(data) index = index_element(cla_arr,data,sw) return center,index,sse1,cla_arrcenter_l, index,sse1, cla_arr = Kmeans(n,sw)print("類別中心為:",center_l)print("所查元素屬于類別:",index)print("k值為{0}時的誤差平方和為{1}".format(k,sse1))#format格式化占位輸出誤差平方和def visualization(cla):#聚類可視化展現 cla_x = [[]] cla_y = [[]] for m in range(k-1):#創建與k值相同維度的空數組存取x坐標和y坐標 cla_x.append([]) cla_y.append([]) for i in range(k):#遍歷k次讀取k個類別 for j in cla[i]:#遍歷每一類存取橫縱坐標 cla_x[i].append(j[0]) cla_y[i].append(j[1]) plt.rcParams["axes.unicode_minus"] = False plt.rcParams["font.sans-serif"]=["SimHei"]#解決中文不能顯示的問題 plt.figure() plt.xlabel("x") plt.ylabel("y") plt.title("聚類圖") plt.scatter(cla_x[0],cla_y[0],c = "r",marker = "h") plt.scatter(cla_x[1], cla_y[1], c="y", marker=".") plt.scatter(cla_x[2], cla_y[2], c="g", marker="o") plt.scatter(cla_x[3], cla_y[3], c="b", marker=",") plt.scatter(cla_x[4], cla_y[4], c="k", marker="p") plt.show()visualization(cla_arr)def hand():#畫出手肘圖 #sse列表是循環次數為3,改變k從2到8一個一個人工測得存入 sse = [17.840272113687078,12.116153021227769,8.563862232332205,4.092534331364449,3.573312882789776,3.42794767600246,3.2880646083752185] x = np.linspace(2,8,7)#創建等間距大小為7的數組 plt.xlabel("k值")#橫坐標名稱 plt.ylabel("誤差平方和")#縱坐標名稱 plt.title("手肘圖")#曲線名 plt.plot(x,sse)#畫出曲線 plt.show()hand()
?
?
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/123201.html
摘要:指定最大迭代次數的整數要求的準確性重復試驗算法次數,將會返回最好的一次結果該標志用于指定初始中心的采用方式。第一列對應于所有個人的高度,第二列對應于它們的權重。類似地,剩余的行對應于其他人的高度和重量。 K-Means Clustering in OpenCV cv2.kmeans(data, K, bestLabels, criteria, attempts, flags[, cen...
摘要:聚類算法簡介聚類的目標是使同一類對象的相似度盡可能地大不同類對象之間的相似度盡可能地小。用戶地理位置信息的的聚類實現本實驗用實現,依賴等科學計算。 1. 聚類算法簡介 聚類的目標是使同一類對象的相似度盡可能地大;不同類對象之間的相似度盡可能地小。目前聚類的方法很多,根據基本思想的不同,大致可以將聚類算法分為五大類:層次聚類算法、分割聚類算法、基于約束的聚類算法、機器學習中的聚類算法和用...
摘要:算法的關鍵在于初始中心的選擇和距離公式。并行設置的實現算法,有其中表示用方式實現雖然有很多參數,但是都已經給出了默認值。 K-means算法簡介 K-means是機器學習中一個比較常用的算法,屬于無監督學習算法,其常被用于數據的聚類,只需為它指定簇的數量即可自動將數據聚合到多類中,相同簇中的數據相似度較高,不同簇中數據相似度較低。 K-menas的優缺點: 優點: 原理簡單 速度快 ...
閱讀 3220·2021-11-12 10:36
閱讀 1288·2019-08-30 15:56
閱讀 2449·2019-08-30 11:26
閱讀 559·2019-08-29 13:00
閱讀 3616·2019-08-28 18:08
閱讀 2755·2019-08-26 17:18
閱讀 1907·2019-08-26 13:26
閱讀 2438·2019-08-26 11:39