【机器学习】K近邻#1基于Scikit-Learn的K近邻分类

主要参考学习资料:

《机器学习算法的数学解析与Python实现》莫凡 著

《机器学习实战 基于Scikit-Learn、Keras和TensorFlow》Aurélien Géron 著

前置知识:线性代数-Python

数学模型

参数模型与非参数模型

机器学习算法可以分为参数模型非参数模型。参数模型从数据集估计参数来学习,对新数据点的预测不再需要原始训练数据集。非参数模型不能用一组固定的参数来描述,参数的个数随着训练数据的增加而增长。

K近邻 (KNN)分类器与其他学习算法有本质的不同,属于惰性学习 算法,不是从训练数据中学习判别函数,而是靠记忆训练过的数据集来完成任务,是基于实例的学习,属于非参数模型。

距离度量

K近邻算法本身不涉及数学知识,但查找最近邻的过程用到了距离的数学度量方法。

闵可夫斯基距离对一类距离度量进行了统一定义,其数学表达式如下:

d P ( x , y ) = ( ∑ i = 1 n ∣ x i − y i ∣ P ) 1 / P d_P(x,y)=\displaystyle(\sum^n_{i=1}|x_i-y_i|^P)^{1/P} dP(x,y)=(i=1∑n∣xi−yi∣P)1/P

其中 x x x和 y y y代表两个点, n n n代表维数,下标 i i i代表点的第 i i i维坐标。

通过给 P P P设置不同的值可以得到不同的距离表达式。

当 P = 1 P=1 P=1时,得到曼哈顿距离

d ( x , y ) = ∑ k = 1 n ∣ x k − y k ∣ d(x,y)=\displaystyle\sum^n_{k=1}|x_k-y_k| d(x,y)=k=1∑n∣xk−yk∣

在二维空间下,曼哈顿距离的意义是从一点只沿横轴和纵轴方向行驶到另一点的轨迹长度。

当 P = 2 P=2 P=2时,得到欧几里得距离

d 2 ( x , y ) = ∑ i = 1 n ( x i − y i ) 2 d_2(x,y)=\displaystyle\sqrt{\sum^n_{i=1}(x_i-y_i)^2} d2(x,y)=i=1∑n(xi−yi)2

其意义为两点之间的直线距离。

K近邻算法

①选择个数K和一个距离度量。

②以待分类样本点为中心,分别测量它到其他点的距离,找出其中距离最近的K个,即K个最近邻。

③统计出每种类别在最近邻中的占比,选取占比最多的类别作为待分类样本的类别。

代码实现

KNN算法可视化代码与Logistic回归类似:

python 复制代码
from sklearn.datasets import load_iris  
#导入KNeighborsClassifier类
from sklearn.neighbors import KNeighborsClassifier  
import numpy as np  
import matplotlib.pyplot as plt  
iris = load_iris()  
X = iris.data[:, :2]
y = iris.target  
#训练KNN模型
clf = KNeighborsClassifier().fit(X, y)  
#可视化
def plot_decision_boundary(X, y, model):  
    x_min, x_max = X[:, 0].min() - 1, X[:, 0].max() + 1  
    y_min, y_max = X[:, 1].min() - 1, X[:, 1].max() + 1  
    xx, yy = np.meshgrid(np.arange(x_min, x_max, 0.01), np.arange(y_min, y_max, 0.01))  
    Z = model.predict(np.c_[xx.ravel(), yy.ravel()])  
    Z = Z.reshape(xx.shape)  
    plt.contourf(xx, yy, Z, alpha=0.8, cmap=plt.cm.coolwarm)  
    plt.scatter(X[:, 0], X[:, 1], c=y, edgecolors='k', marker='o', cmap=plt.cm.coolwarm)  
    plt.xlabel('Feature 1')  
    plt.ylabel('Feature 2')  
    plt.title('KNN Decision Boundary')  
    plt.show()  
plot_decision_boundary(X, y, clf)

可视化结果:

特点

优点:理论形式简单,容易实现,新加入数据时不必对整个数据集进行重新训练,可以实现在线训练。

缺点:对样本分布比较敏感,正负样本不平衡时会对预测有明显影响,数据集规模大时计算量将加大。

应用领域:模式识别、文本分类、多分类领域。

相关推荐
wow_DG6 分钟前
【PyTorch✨】01 初识PyTorch
人工智能·pytorch·python
海绵波波10718 分钟前
解读LISA:通过大型语言模型实现推理分割
人工智能·语言模型·自然语言处理
暖苏42 分钟前
python-异常(笔记)
大数据·开发语言·笔记·python·异常
昨日之日200643 分钟前
FLUX.1 Kontext Dev V2版 - 消费级显卡(6G显存)畅玩的AI修图神器 支持批量 支持多图融合编辑 支持50系显卡 一键整合包下载
人工智能
海森大数据1 小时前
神经网络“开窍”时刻:从死记位置到理解意义的语言奇点
人工智能·深度学习·神经网络
贾全1 小时前
Transformer架构全解析:搭建AI的“神经网络大厦“
人工智能·神经网络·ai·语言模型·自然语言处理·架构·transformer
这是一只菜狗啊1 小时前
使用神经网络与5折交叉验证进行基因组预测:基础知识指南
人工智能·深度学习·神经网络
缘友一世1 小时前
Agents-SDK智能体开发[1]之入门
人工智能·agent·agents_sdk
啊阿狸不会拉杆1 小时前
《Java 程序设计》核心知识点梳理与深入探究
java·开发语言·python·算法·php·intellij-idea
行然梦实2 小时前
世代距离(GD)和反转世代距离(IGD)详析
人工智能·算法·机器学习·数学建模