cv2机器学习-K近邻(KNN)

本文详细介绍了如何使用cv2模块的K近邻(KNN)算法进行分类。通过示例展示了KNN的工作原理,包括距离权重的影响以及k值的选择。并应用KNN进行手写数字识别,展示了训练过程和预测结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本篇博客主要介绍cv2模块机器学习部分中的K近邻,k近邻即根据k各最近的值进行分类的方法,即KNN。在KNN中,距离近的具有更高的权重值,k的取值最好为奇数。

# encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt

# Feature:设置为25行2列的包含(x,y)的已知的训练数据
trainData = np.random.randint(0, 100, (25, 2)).astype(np.float32)
# print(trainData)
# labels:设置为0:代表Red, 1:代表Blue
labels = np.random.randint(0, 2, (25, 1)).astype(np.float32)
# print(labels)

# 找出红色并绘制
# print(labels.ravel())
red = trainData[labels.ravel() == 0]    # ravel()降维
plt.scatter(red[:, 0], red[:, 1], 80, 'r', '^')  # 绘制三角散点图
# 找出蓝色并绘制
blue = trainData[labels.ravel() == 1]
plt.scatter(blue[:, 0], blue[:, 1], 80, 'b', 's')


# 测试数据被标记为绿色
'''
返回值包括:
1、由KNN算法计算得到的测试数据的类别标志0或1,
如果想要使用最近邻算法,只需将k置为1。
2、k个最近邻居的类别标志。
3、每个最近邻居到测试数据的距离
'''
ne
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

cchangcs

谢谢你的支持~

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

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

打赏作者

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

抵扣说明:

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

余额充值