K-Means算法与PLT可视化

news/2025/1/1 7:44:48/
  • 专栏《Python编程杂记》

K-Means概念

  • K均值聚类算法(k-means clustering algorithm)是一种迭代求解的聚类分析算法,其步骤是,预将数据分为K组,则随机选取K个对象作为初始的聚类中心,然后计算每个对象与各个种子聚类中心之间的距离,把每个对象分配给距离它最近的聚类中心。聚类中心以及分配给它们的对象就代表一个聚类。每分配一个样本,聚类的聚类中心会根据聚类中现有的对象被重新计算。这个过程将不断重复直到满足某个终止条件。终止条件可以是没有(或最小数目)对象被重新分配给不同的聚类,没有(或最小数目)聚类中心再发生变化,误差平方和局部最小。

概述

  • 此篇代码为Python生成指定数量的随机点,同时内定几个初始随机点,遍历计算各点到这些随机点的距离(坐标系下两点间距离公式),最终将各点归类,此即K-Means算法。最后通过Python的PLT库进行可视化。

参数

  1. K-Means的分类数K(小于随机点数目即可);
  2. 需要的随机点数目(尽可能多,最好超过K的20倍);
  3. 可视化坐标轴刻度(一般取随机点数的一半,不固定)。

可选三个参数

运行过程提示

运行过程

运行结果可视化

  • 图中三个区域中心点为三个不同颜色,与其相邻且同色的点归为一簇。

使用PLT可视化

代码

import math
import time
import random
import matplotlib.pyplot as pltclass KMeans:def __init__(self, k, pointsAcount, dataRange):self.k = int(k)self.pointsAcount = int(pointsAcount)self.dataRange = int(dataRange)self.dataset = []self.startPooints = []def generateDataset(self):Xs = []Ys = []a = 0while a < self.pointsAcount:Xs.append(random.randint(0, self.dataRange))Ys.append(random.randint(0, self.dataRange))a += 1self.dataset.append(Xs)self.dataset.append(Ys)return self.datasetdef distanceFormula(self, point1, point2):distance = math.sqrt((point1[0] - point2[0])**2 + (point1[1] - point2[1])**2)return distancedef getMin(self, compareList):minNum = compareList[0]minIndex = 0for i in range(len(compareList)):if compareList[i] < minNum:minNum = compareList[i]minIndex = ireturn minNum, minIndexdef randomStart(self):newDataset = self.dataset.copy()newDataset.append([])a = 0print() # 格式控制while a < self.k:positon = random.randint(0, self.pointsAcount - 1)newDataset[2].append([newDataset[0][positon], newDataset[1][positon]])a += 1print('起始中心点 {} 为: ( {:.5f} , {:.5f} )'.format(str(a), newDataset[0][positon], newDataset[1][positon]))return newDatasetdef generateClusters(self, newDataset):# 准备a = 0clusterList = []while a < self.k:clusterList.append([])a += 1# 计算各点到起始点的距离distanceDict = {}startPointIndex = 0for startPoint in newDataset[2]:distanceDict.setdefault(str(startPointIndex), [])for p in range(self.pointsAcount):if [newDataset[0][p], newDataset[1][p]] in newDataset[2]:passelse:anotherPoint = [newDataset[0][p], newDataset[1][p]]distance = self.distanceFormula(startPoint, anotherPoint)distanceDict[str(startPointIndex)].append(distance)startPointIndex += 1# 比较各点到起始点距离,近的归为一簇for p in range(self.pointsAcount-self.k):compareList = []for k in range(self.k):compareList.append(distanceDict[str(k)][p])minDistance, minIndex = self.getMin(compareList)clusterList[minIndex].append(p)# 计算各簇平均值点newDataset[2].clear()a = 0for cluster in clusterList:Xs = 0Ys = 0for p in cluster:Xs += newDataset[0][p]Ys += newDataset[1][p]newStartPoint = [Xs/len(cluster), Ys/len(cluster)]newDataset[2].append(newStartPoint)a += 1print('新的中心点 {} 为: ( {:.5f} , {:.5f} )'.format(str(a), Xs/len(cluster), Ys/len(cluster)))return newDataset[2], clusterListdef randomColor(self):colorArr = ['1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F']color = ''for i in range(6):color += colorArr[random.randint(0, 14)]return '#' + colordef drawDataset(self, startPointList, clusterList):plt.title('K-Means Clustering Results')plt.xlabel('X')plt.ylabel('Y')for startPoint in startPointList:startPointColor = self.randomColor()plt.plot(startPoint[0], startPoint[1], color=startPointColor, marker='o')for cluster in clusterList:pointColor = self.randomColor()for p in cluster:plt.plot(self.dataset[0][p], self.dataset[1][p], color=pointColor, marker='.')plt.show()def runKMeans(self):startTime = time.time()self.generateDataset()newDataset = self.randomStart()lastStartPointList = []print('\n开始第 1 次迭代...')newStartPointList, clusterList = self.generateClusters(newDataset)iteration = 2while lastStartPointList != newStartPointList:print('\n开始第 ' + str(iteration) + ' 次迭代...')newDataset = self.dataset.copy()newDataset.append(newStartPointList)lastStartPointList = newStartPointList.copy()newStartPointList, clusterList = self.generateClusters(newDataset)iteration += 1print() # 格式控制k = 0while k < self.k:print('迭代完毕,最终中心点 {} 为: ( {:.5f} , {:.5f} )'.format(str(k+1), newStartPointList[k][0], newStartPointList[k][1]))k += 1endTime = time.time()print('\n共耗费时间: ' + str(endTime-startTime))self.drawDataset(newStartPointList, clusterList)if __name__ == '__main__':# dataRange表示坐标轴长度刻度最大值KMeans = KMeans(k=input('请输入K值:'),pointsAcount=input('请输入随机点个数:'),dataRange=input('请输入坐标轴最大刻度:'))KMeans.runKMeans()
  • 学如逆水行舟,不进则退!
  • (ง •̀-•́)ง

http://www.ppmy.cn/news/231438.html

相关文章

机器学习----聚类之k-means

&#xff08;一&#xff09;、K-Means聚类算法 KMeans是聚类算法的一种&#xff0c;先来直观的看一下该算法是怎样聚类的。给定一组数据如下图所示&#xff0c;K-Means算法的聚类流程如图&#xff1a; 图中显示了Kmeans聚类过程&#xff0c;给定一组输入数据{x(1),x(2),...,x(…

韦伯分布(Weibull)参数矩估计MATLAB实现

韦伯分布(Weibull)参数矩估计MATLAB实现 二参数韦伯分布概率密度函数 f ( x ) β η ( x η ) β − 1 e − ( x η ) β , β > 0 , η > 0 , x ≥ γ ≥ 0 f(x)\frac{\beta}{\eta}\left(\frac{x}{\eta}\right)^{\beta-1} e^{-\left(\frac{x}{\eta}\right)^{\beta}}, …

Tensorflow 保存卷积神经网络模型参数

Tensorflow 保存卷积神经网络模型参数 Tensorflow 保存卷积层参数 Tensorflow 保存卷积层参数 import numpy as np import tensorflow as tf import matplotlib.pyplot as pltfrom tensorflow.examples.tutorials.mnist import input_data print ("packs loaded")pa…

hot-S22和X参数的原理(转)

什么是 X 参数 - X Parameters 概念 在微波射频电路设计中&#xff0c;S 参数是最被广泛使用的、描述射频与微波网络特性的参量。S 参数定义了两(多)端口网络输入和输出的关系&#xff1a; S 参数非常适用进行射频、微波网络级联分析&#xff1b;根据 S 参数的定义&#xff0c…

【MDT】iPhone XS 系列屏幕素质报告

iPhone XS 与 iPhone XS Max 均采用了 Apple 官方称之为&#xff1a;「超视网膜高清显示屏 」的新一代 OLED 屏幕&#xff0c;除了大小不同以及分别率分别为 2436 x 1125 和 2688 x 1242 之外&#xff0c;其他参数都没有差别&#xff0c;均为 458 PPI, P3 色域。 1/3 色域测试 …

Python函数参数传递,返回值

文章目录 位置实参传递&#xff0c;即一对一传递&#xff0c;传递顺序不能乱关键字实参传递&#xff0c;f(arg1...,arg2...,...)默认值&#xff0c;传递传递任意数量的实参使用任意数量的关键字实参返回值 返回字典传递列表&#xff0c;可以在函数中修改列表&#xff0c;以及如…

Mnist数据集单隐层BP神经网络参数调优

本次对mnist数据集采用单隐层的BP神经网络&#xff0c;在对参数初始化&#xff0c;激活函数&#xff0c;学习率&#xff0c;正则系数选择&#xff0c;隐层神经元数量选择&#xff0c;随机采样样本数量进行调优后&#xff0c;模型在测试集上的正确率可以达到98%。 1、 参数初始…

[吴恩达机器学习笔记]13聚类K-means

13.聚类 觉得有用的话,欢迎一起讨论相互学习~ 吴恩达老师课程原地址 13.1无监督学习简介 从监督学习到无监督学习 在一个典型的监督学习中&#xff0c;我们有一个有标签的训练集&#xff0c;我们的目标是找到能够区分正样本和负样本的决策边界&#xff0c;在监督学习中&…