sklearn K最近邻(knn)多分类问题

模型

sklearn.neighbors类库里有4个主要的模型,k最邻近:KNeighborsClassifierKNeighborsRegressor;半径最邻近:RadiusNeighborsClassifierRadiusNeighborsRegressor。classifier分类,regression回归
这里使用KNeighborsClassifier
参数详解
最重要两个参数:metric knn的距离计算方式和n_neighbors k的大小。

预处理

import pandas as pd
path = "../Data/classify.csv"
rawdata = pd.read_csv(path) 
X = rawdata.iloc[:,:13]
Y = rawdata.iloc[:,14]  # {”A":0,"B":1,"C":2}
Y = pd.Categorical(Y).codes  # ABC变成123

建模

from sklearn.neighbors import KNeighborsClassifier
model = KNeighborsClassifier(n_neighbors = k, metric="minkowski")

训练+评价

def svc_model(model):
    model.fit(x_train, y_train)
    acu_train = model.score(x_train, y_train)
    acu_test = model.score(x_test, y_test)
    y_pred = model.predict(x_test)
    recall = recall_score(y_test, y_pred, average="macro")
    return acu_train, acu_test, recall

def knn_model(k):
    return KNeighborsClassifier(n_neighbors = k, metric="minkowski")

def run_knn(kmax):
    result = {
              "k":[],
              "acu_train": [],
              "acu_test": [],
              "recall": []
              }
    for i in range(1,kmax+1):
        acu_train, acu_test, recall = svc_model(knn_model(i))
        result["k"].append(i)
        result["acu_train"].append(acu_train)
        result["acu_test"].append(acu_test)
        result["recall"].append(recall)
    return pd.DataFrame(result)
run_knn(20)

然后更改model里的metric再跑几遍

结果

在这里插入图片描述
随着k值增大,准确率先升后降,存在最优的k值。曼哈顿距离在本例中是比较好的。分类准确率最高达到了80%

补充:RadiusNeighborsClassifier和KNeighborsClassifier差不多,只不过要设置的是radius而不是k。radius如果设小了会无法分类。所以多试几遍。本例radius得55以上,最高的准确率不超过70%,所以没有使用也没有写。

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
K最近邻(K-Nearest Neighbors,KNN算法是一种常用的多分类算法。它基于样本之间的距离来进行分类,具体操作如下: 1. 计算距离:对于测试样本,计算它与训练集中每个样本的距离。常见的距离度量方法有欧氏距离、曼哈顿距离等。 2. 选择K个最近邻:根据距离,选择与测试样本最近的K个训练样本。 3. 进行投票或求平均:根据K个最近邻样本的标签,进行投票决策或求平均值,得到测试样本的分类结果。 以下是一个使用K最近邻算法进行多分类Python代码示例: ```python from sklearn.neighbors import KNeighborsClassifier import pandas as pd from sklearn.model_selection import train_test_split # 读取数据集 data = pd.read_csv('final_data1.csv') Y = data.y X = data.drop('y', axis=1) # 数据集划分为训练集和测试集 X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.2, random_state=42) # 创建并训练KNN分类器 knn = KNeighborsClassifier(n_neighbors=3) # 设置K值为3 knn.fit(X_train, y_train) # 在测试集上进行预测 y_pred = knn.predict(X_test) ``` 上述代码使用了`sklearn`库中的`neighbors`模块,通过导入`KNeighborsClassifier`创建了一个K最近邻分类器对象`knn`。在创建分类器对象时,通过参数`n_neighbors`设置了K的值为3。然后使用训练集数据`X_train`和对应的标签`y_train`调用`knn.fit()`方法进行训练。最后,使用训练好的模型在测试集数据`X_test`上进行预测,预测结果存储在`y_pred`中。 需要注意的是,KNN算法的性能很大程度上依赖于选择合适的K值和距离度量方法。在实际应用中,可以使用交叉验证等方法来选择最佳的K值,并根据数据集的特点选择合适的距离度量方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值