IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> kNN 和 K_means异同 -> 正文阅读

[人工智能]kNN 和 K_means异同

问题背景

? ? ? ? ? 我有时会搞混,所以写一篇博客来记录下自己的理解

KNN

  • 分类算法
  • 监督学习,数据集是带Label的数据
  • 没有明显的训练过程,就是费事儿,每次都要遍历所有已有的样本点去计算距离
  • K值含义 :对于一个样本X,要给它分类,首先从数据集中,在X附近找离它最近的K个数据点,将X划分为K个数据点中类别最多的一类

K-means

  • 聚类算法
  • 非监督学习,数据集是无Label,杂乱无章的数据
  • 有明显的训练过程
  • K值含义:K是事先设定的数字,将数据集分为K个簇,需要依靠人的先验知识

不同点

? ? ? ? ? 两种算法之间的根本区别是,K-means本质上是无监督学习,而KNN是监督学习;K-means是聚类算法,KNN是分类(或回归)算法。

? ? ? ? ? K-means算法把一个数据集分割成簇,有K个簇中心,每个样本 X 属于和 X 距离 最近的簇中心,每次迭代后更新这个簇中心的值,直到簇中心不再变化,请注意,这儿的簇中心不是实际存在的样本点,而是一堆样本的各维度平均值构成的一个虚拟的点。

在这里插入图片描述

代码python

? ? ? ? ? K-means 的代码之前写过了,请参见 k均值算法 动图制作代码

? ? ? ? ? KNN的代码如下

import numpy as np
import xlrd
import collections

"""
函数说明:对数据进行归一化
Parameters:
	dataSet - 特征矩阵
Returns:
	normDataSet - 归一化后的特征矩阵
	ranges - 数据范围
	minVals - 数据最小值
"""
def autoNorm(dataSet):
	minVals = dataSet.min(0)    ## axis 指定成0,获得数据每个特征上的最小值
	maxVals = dataSet.max(0)    ## axis 指定成0,获得数据每个特征上的最大值
	ranges = maxVals - minVals  # 最大值和最小值的范围
	row = dataSet.shape[0]      # 返回dataSet的行数
	normDataSet = (dataSet - np.tile(minVals, (row, 1))) / np.tile(ranges, (row, 1))  # 原始值减去最小值除以最大和最小值的差,得到归一化数据
	return normDataSet, ranges, minVals

"""
函数说明:计算向量与向量(矩阵多个向量)的距离
Parameters:
	new_data - 向量
	base_data - 矩阵或者向量
Returns:
	distances - 距离(单个值或者向量形式)
"""
def calculate_distances(new_data,base_data):
	dataSize  = base_data.shape[0]                              # numpy函数shape[0]返回dataSet的行数
	diffMat   = np.tile(new_data, (dataSize, 1)) - base_data    # 在列向量方向上重复inX共1次(横向),行向量方向上重复inX共dataSetSize次(纵向)
	sqDiffMat = diffMat ** 2                                    # 每个元素后平方
	distances = (sqDiffMat.sum(axis=1)) ** 0.5                  # sum()所有元素相加,sum(0)列相加,sum(1)行相加 开方,计算出距离
	return distances

"""
函数说明:kNN算法,分类器
Parameters:
	inX - 用于分类的数据(测试集)
	dataSet - 用于训练的数据(训练集)
	labes - 分类标签
	k - kNN算法参数,选择距离最小的k个点
Returns:
	sortedClassCount[0][0] - 分类结果
"""
def classify0(inX, dataSet, labels, k):
	distances = calculate_distances(inX,dataSet)                             # 计算距离
	k_labels = [labels[index][0] for index in distances.argsort()[0: k]]     # 距离最近的前k个样本的标签
	label = collections.Counter(k_labels).most_common(1)[0][0]               # 出现次数最多的标签即为最终类别
	return label

"""
函数说明:读取数据函数,算是算法之外的部分
Parameters:
	path - 数据所在目录(在当前目录下,可直接使用文件名,不然则应该为绝对路径)
Returns:
	datamatrix - 数据形式的数据
"""
def excel2matrix(path):
    data = xlrd.open_workbook(path)
    table = data.sheets()[0]
    nrows = table.nrows  # 行数
    ncols = table.ncols  # 列数
    datamatrix = np.zeros((nrows, ncols))
    for i in range(ncols):
        cols = table.col_values(i)
        datamatrix[:, i] = cols
    return datamatrix


if __name__ == "__main__":
	data = excel2matrix("data.xls")
	lables = excel2matrix("labels.xls").astype(int)  # 标签是整数比较好看。清爽

	nom_data, ranges, minVals = autoNorm(data)
	class_number = 3

	test = np.array([0.1,0.4,0.3]).reshape(1, -1)    # 你随便构造一个新样本喽,每个属性都归一化了,所以你的属性取值应该在0-1之间
	test_class = classify0(test, nom_data, lables, class_number)

? ? ? ? ? KNN的的数据集在这儿

链接:https://pan.baidu.com/s/1Zqz_ZBPRi5PqcRPYQAEpPQ
提取码:ray8

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-08-08 11:20:38  更:2021-08-08 11:22:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/12 3:45:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码