Opencv学习笔记 - 使用opencvsharp和knn进行手写识别训练和预测

本文介绍了KNN算法的基础知识,包括样本的特征空间、向量距离计算以及KNN原理。接着,通过OpenCVSharp展示了如何进行手写数字识别,提供了C++和C#的参考代码,利用MNIST数据集进行训练和测试,最终得到的准确率为0.9688。

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

一、KNN概述

        在所有的机器学习算法中,K近邻(KNN)几乎是最简单的,而且它既可用于分类(预测离散的类别标签),也可用于回归(预测连续的实数值)。尽管简单,但事实证明在某些任务中KNN非常有效。因为KNN需要存储所有的训练样本,占用内存很大,所以速度相对较慢。因此在使用KNN之前,常常需要通过聚类降低训练集大小。        

        KNN是最简单的分类算法,也可以用于回归。对于待分类的样本,计算待预测样本和训练集中所有数据点的距离,将距离从小到大取前K个,哪个类别在前K个数据点中的数据最多,就认为待预测样本属于该类别。

1、样本的特征空间

        在训练样本集中,每个样本x都是一个由nx个特征值构成的特征向量x=(x1, …,xnx),因此可以认为每个样本都在一个nx维特征空间内分布。例如,日常生活中所说的三维空间,通常是指由长、宽、高三个维度所构成的空间。三维空间中的每个样本x都可以用包含长、宽、高三个特征的特征向量x=(x1, x2, x3)来唯一描述,显然样本x的分布就是在长、宽、高三个维度的特征空间内的分布。

        对于监督学习来说,每个样本都有一个标签y, 分类算法或回归算法的目的就是找到一个函数f,y=f(x),使得以足够高的精

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

坐望云起

如果觉得有用,请不吝打赏

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

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

打赏作者

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

抵扣说明:

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

余额充值