K-MEANS 算法的简单实现

K-MEANS 算法的简单实现

目的是为了自己熟悉 K 均值的过程

思路:

如何写一个 KMEANS 算法呢
我们就做一个最简单的,所有的数据都是点,也就是只有横纵坐标。
数据的格式我们用一个数组来进行表示,数组有两个值,一个是 x 的值,另一个是 y 的值
x = [1,1,2,2,4,4,5,5]
y = [1,2,1,2,4,5,4,5]

步骤:

1. 通过要分成的类别数目随机找到中心点
2. 遍历所有根据中心点计算距离,比较距离进行分类
3. 在每一个类别中,求平均点,再次遍历所有点重新进行分类,以此往复知道类别中的数量不再变化,或者达到最大迭代步数
"""
如何写一个 KMEANS 算法呢
我们就做一个最简单的,所有的数据都是点,也就是只有横纵坐标。
数据的格式我们用一个数组来进行表示,数组有两个值,一个是 x 的值,另一个是 y 的值
x = [1,1,2,2,4,4,5,5]
y = [1,2,1,2,4,5,4,5]步骤:1. 通过要分成的类别数目随机找到中心点2. 遍历所有根据中心点计算距离,比较距离进行分类3. 在每一个类别中,求平均点,再次遍历所有点重新进行分类,以此往复知道类别中的数量不再变化,或者达到最大迭代步数"""
import copy
import math
import random
import numpy as np
x = [1, 1, 2, 2, 4, 4, 5, 5,3.5,4.5]
y = [1, 2, 1, 2, 4, 5, 4, 5,3.4,3.5]def calc_dist(x, y):return math.sqrt((x[0] - x[1]) ** 2 + (y[0] - y[1]) ** 2);def KMEANS(dots: list, category: int, max_step: int):# 1. 随机找个类别个中心点X = dots[0]Y = dots[1]dots_len = len(X)centers = []for i in range(category):index = random.randint(0, dots_len - 1)centers.append([X[index], Y[index]])result = [] # 记录所有迭代的次数# 2. 根据中心点去计算距离step = 0while True :if step != 0 : # 这里就是第二步,重新计算中心点,如果中心点一致,那么就退出迭代old_centers = copy.deepcopy(centers)centers = []for key,value in result[step-1].items():sum = 0x_avg = 0for i in value[0]:sum += ix_avg = sum / len(value[0])sum = 0y_avg = 0for i in value[1]:sum += iy_avg = sum / len(value[1])centers.append([x_avg, y_avg])is_same = all(set(i) == set(j) for i, j in zip(old_centers, centers))if is_same :breakcategories = {}for i in range(len(centers)):categories[str(centers[i])] = [[], []]for i in range(dots_len):temp = {}for j in range(len(centers)):temp[str(centers[j])] = calc_dist([centers[j][0], X[i]], [centers[j][1], Y[i]])min_value_key = min(temp, key=temp.get)value = categories[min_value_key]value[0].append(X[i])value[1].append(Y[i])categories[min_value_key] = valueresult.append(categories)step += 1print(step)return result[len(result)-1]result = KMEANS([x,y],2,12)
print(result)
import matplotlib.pyplot as plt
colors = ['red', 'blue', 'green', 'orange', 'purple', 'cyan', 'magenta']
step = 0
for value in result.values():color = colors[step]print(color)plt.scatter(value[0],value[1],c=color)step+=1plt.show()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/854610.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java @Aysn实现异步 及导致失效原因

在 Java 中,Async 注解用于表明一个方法是异步执行的。这意味着方法会在调用时立即返回,而不会等待方法体内的代码执行完毕。这对于需要异步执行长时间操作的方法非常有用,比如发送邮件、处理大量数据等。 1.使用实例 假设有一个 Spring Boo…

12.1 Go 测试的概念

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

python之面向对象编程

01 第一步 创建类&#xff0c; self指向调用该函数的对象 也就是通过类实例出来的对象 class Person():def __init__(self):self.name zsself.age 12def fn(self):print(self)p1 Person() print(p1) # <__main__.Person object at 0x000002509F331790> print(p1.fn()…

独孤思维:和副业付费学员吵架了

01 之前和老婆出去逛街。 很久没有静下心来&#xff0c;谈这么久。 聊到工作副业&#xff0c;孩子教育。 发现很多内容都存在偏差&#xff0c;之前一直没有深思讨论过。 经过这一次讨论之后&#xff0c;更优化了关于小孩的教育观&#xff0c;关于工作和副业的平衡问题。 …

LeetCode 0522.最长特殊序列 II:两句话讲明思路(子序列判断)

【LetMeFly】522.最长特殊序列 II&#xff1a;两句话讲明思路(子序列判断) 力扣题目链接&#xff1a;https://leetcode.cn/problems/longest-uncommon-subsequence-ii/ 给定字符串列表 strs &#xff0c;返回其中 最长的特殊序列 的长度。如果最长特殊序列不存在&#xff0c;…

VM4.3 二次开发02 方案加载、执行及显示

效果 这是二次开发的第二个文章&#xff0c;所以不重复说明环境配置相关的内容。如果不懂的可以看本专栏的上一个文章。 海康视觉算法平台VisionMaster 4.3.0 C# 二次开发01 加载方案并获取结果-CSDN博客 界面代码 <Window x:Class"VmTestWpf.App.MainWindow"x…

element-plus的Tour 漫游式引导怎么去绑定Cascader 级联选择器

首先官方例子是用的button 官方.$el这个log出来是&#xff1a; 知道是以元素为准就拿对应的元素就行 级联选择器.$el是这样的&#xff1a; 你可以移入这个元素部分去看看是哪个要用的&#xff08;好像火狐直接放上去就可以看到元素表示&#xff0c;谷歌要双击或者右键选择去看…

手机ip地址怎么换成成都的

随着互联网的快速发展&#xff0c;我们越来越依赖于网络进行各种操作。而在某些情况下&#xff0c;为了更好地享受网络服务或保护个人隐私&#xff0c;我们可能需要改变手机的IP地址。本文将详细介绍如何将手机IP地址换成成都的&#xff0c;同时提醒大家在操作过程中需要注意的…

ts-node

ts-node 是一个 TypeScript 执行引擎&#xff0c;它允许您直接运行 TypeScript 代码&#xff0c;而无需先将其编译为 JavaScript。这在开发和测试过程中非常有用&#xff0c;可以提高开发效率。以下是关于 ts-node 的一些基本信息和使用方法。 安装 您可以通过 npm 或 yarn 安…

【AI开发】CRAG、Self-RAG、Adaptive-RAG

先放一张基础RAG的流程图 https://blog.langchain.dev/agentic-rag-with-langgraph/ 再放一个CRAG和self-RAG的LangChain官方博客 Corrective RAG(CRAG) 首先需要知道的是CRAG的特色发生在retrieval阶段的最后开始&#xff0c;即当我们获得到了近似的document&#xff08;或者…

(day1)数据类型详解及DML语句入门

一、数据类型 1、整型类型 &#xff08;1&#xff09;创建数据库 CREATE DATABASE ql_linux&#xff1b; CREATE SCHEMA IF NOT EXISTS ql_linux&#xff1b; //IF NOT EXISTS如果没有表就创建 SHOW DATABASE; //查看数据库 &#xff08;2&#xff09;创建表 C…

【仿真建模-anylogic】Conveyor Network理念解析

Author&#xff1a;赵志乾 Date&#xff1a;2024-06-17 Declaration&#xff1a;All Right Reserved&#xff01;&#xff01;&#xff01; 1. 概念 Conveyor Network由物料处理库中的多种空间标记元素所构成的图形化运输网&#xff0c;如&#xff1a;Conveyor、Station、Turn…

【Git】-- 添加公钥到 github 或者gitlab上

仅针对系统&#xff1a;mac os 、 unix、linux 1、检查是否有 id_rsa.pub $ cd ~ $ ls -al ~/.ssh 注意&#xff1a;若已有 id_rsa.pub&#xff0c;则必要执行 第二步&#xff0c;避免覆盖掉原有正常的公钥。 配置多个 git 账号请参考&#xff1a;同一台电脑配置多个git账…

每日一题——Python实现PAT甲级1132 Cut Integer(举一反三+思想解读+逐步优化)五千字好文

一个认为一切根源都是“自己不够强”的INTJ 个人主页&#xff1a;用哲学编程-CSDN博客专栏&#xff1a;每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 我的写法 正确性和功能性 时间复杂度 空间复杂度 其他点评 总结 我要更强 优化后…

黑马苍穹外卖1 Git+Nginx反向代理+员工登录表加密+Swagger

整体结构 前端 &#xff1a;管理端Web/用户端(小程序) 后端&#xff1a;后端服务&#xff08;java&#xff09; 1 直接使用前端环境 2后端环境搭建 3 完善登录功能 后端环境搭建基于Maven&#xff0c;分模块开发 common公共类&#xff1a;constant常量类、、、、 pijo类:实…

SQL:按用户名复制权限

生产系统中有一个模块是管理用户及菜单权限&#xff0c;它们是由3个数据表组成&#xff0c;关系及字段如下&#xff1a; 原来为每个用户添加菜单的访问权限时都是一个一个添加&#xff0c;但今天遇到有个新来的员工&#xff0c;需要具有与另一个员工相同的权限。新建一个用户后…

vue3 中实现 验证码发送 刷新不变倒计时

今天实现一个倒计时的功能 在平常开发前端的功能的时候 不管是 移动端还是web端 我们都会有注册 登录 中的发送验证码功能 实现绑定以及注册功能。今天我主要分享一下当前的验证码实现原理。 有两种做法(我目前认为以及看到的) ① 做一个简单的倒计时 ② 实时监测倒计时 刷…

前端RSA加解密(支持超长分段)

过程不复杂, 只是网上结合后端的RSA加解密资料参差不齐, 比较零散, 而且大多博文都是基于最原始的RSA加解密, 当加解密参数过长的时候, 会报[Message too long for RSA] 解决方案, 找了一圈, 都不大完整, 完整的又很复杂, 加了一堆方法, 看着都头疼! 其实加解密的本质都一样的,…

今日AI资讯-20240615

1. Follow Your Emoji 一键让照片变表情包 腾讯混元联合港科大、清华大学联合推出肖像动画生成框架Follow Your Emoji&#xff0c;可以通过人脸骨架信息生成任意风格的脸部动画&#xff0c;一键创建表情包。基于算法革新和数据积累&#xff0c;Follow Your Emoji可以支持对脸部…

中电金信:银行业数据中心何去何从

20多年前&#xff0c;计算机走进国内大众视野&#xff0c;计算机行业迎来在国内的高速发展时代。银行业是最早使用计算机的行业之一&#xff0c;也是计算机技术应用最广泛、最深入的行业之一。近年来&#xff0c;随着银行竞争加剧&#xff0c;科技如何引领业务、金融科技如何发…