在OpenCV Python中实现k近邻?
k近邻 ( kNN ) 是一种用于监督学习的简单分类算法。要在OpenCV中实现 kNN ,您可以按照下面给出的步骤进行操作:
- 导入所需的库 OpenCV, NumPy 和 Matplotlib
-
我们定义了两个类Red和Blue,每个类都有25个数字。然后使用随机生成器为这两个类生成训练数据。
-
接下来,我们为每个训练数据生成标签。红色家族数字的标签是0,蓝色家族成员的标签是1。
-
现在绘制红色和蓝色家庭成员。
-
使用随机生成器生成一个新的数字并绘制它。
-
初始化一个KNearest对象 knn 并用训练数据进行训练。
-
最后,计算新数字的 knn.findNearest() 以查找新成员的类标签、最近邻居的类标签和距离。
让我们看一下下面的例子来实现k-近邻。
例子
在这个例子中,我们为红色和蓝色家族各生成并绘制了25个训练数据。
输出
当您运行上述Python程序时,它将产生以下“ 输出 ”窗口−
例子
在这个例子中,我们为红色和蓝色家族各生成并绘制了25个训练数据。然后我们生成一个新数字并使用K近邻算法对其进行分类,将其归类为红色或蓝色的家族成员。
输出结果
当您运行上述Python程序时,将产生以下输出: 输出 −
结果显示,该点属于蓝色家族,因为最近的三个邻居中有两个属于蓝色家族。它还会显示以下 输出 窗口: