ValueError: Expected n_neighbors n_samples but n_samples 4 n_neighbors 5

95 篇文章 11 订阅
2 篇文章 0 订阅

解决ValueError: Expected n_neighbors <= n_samples, but n_samples = 4, n_neighbors = 5问题
在进行mtcnn+facenet+knn的人了识别时
报了:
ValueError: Expected n_neighbors <= n_samples, but n_samples = 4, n_neighbors = 5
错误。

1、错误原因:训练集中样本个数比默认的 k 要少,无法找出前k个距离以至无法投票进行分类。

以简单的例子说明:

# 原来的代码
import numpy as np
from sklearn import neighbors
 
group = np.array([[1,101],[5,89],[108,5],[115,8]]) # 训练集   
labels = np.array(['级别A','级别A','级别B','级别B']) # 训练集对应的类别标签
 
knn = neighbors.KNeighborsClassifier()
model=knn.fit(group,labels)  # 训练分类模型
 
print(knn.predict([[101,20]])) # 预测[101,20]属于哪类

上面的代码报错。KNeighborsClassifier()中的参数n_neighbors默认等于5,而训练集样本只有4个,无法分类。

2.1、解决方式一:更改默认的n_neighbors参数值,使参数值小于训练集中的样本个数

# 修改参数后代码
import numpy as np
from sklearn import neighbors
 
group = np.array([[1,101],[5,89],[108,5],[115,8]]) # 训练集   
labels = np.array(['级别A','级别A','级别B','级别B']) # 训练集对应的类别标签
 
knn = neighbors.KNeighborsClassifier(n_neighbors=3) # n_neighbors改为3
model=knn.fit(group,labels)  # 训练分类模型
 
print(knn.predict([[101,20]])) # 预测[101,20]属于哪类

2.2、解决方式二:增加训练集样本的个数,使分类更加准确。

在我的工程中。我是在_classification.py改了
在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

翟羽嚄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值