opencv-python下简单KNN分类识别
KNN是数据挖掘中一种简单算法常用来分类,此次用来聚类实现对4种花的简单识别。
环境:python2.7+opencv3.0+windows10
原理:在使用KNN函数提取出4种花特征点以后,对需要辨认的图片提取体征点,与图库中4类花进行比较,匹配点最多的一类即视为同类。
代码:
读入图像数据:
img =cv2.imread(name)
q_img=[1]*10
q_img[0] = cv2.imread("images/qiangwei1.jpg")
q_img[1] = cv2.imread("images/qiangwei2.jpg")
q_img[2] = cv2.imread("images/qiangwei3.jpg")
q_img[3] = cv2.imread("images/qiangwei4.jpg")
q_img[4] = cv2.imread("images/qiangwei5.jpg")
x_img=[1]*10
x_img[0] = cv2.imread("images/xinghua1.jpg")
x_img[1] = cv2.imread("images/xinghua2.jpg")
x_img[2] = cv2.imread("images/xinghua3.jpg")
x_img[3] = cv2.imread("images/xinghua4.jpg")
x_img[4] = cv2.imread("images/xinghua5.jpg")
t_img=[1]*10
t_img[0] = cv2.imread("images/taohua1.jpg")
t_img[1] = cv2.imread("images/taohua2.jpg")
t_img[2] = cv2.imread("images/taohua3.jpg")
t_img[3] = cv2.imread("images/taohua4.jpg")
t_img[4] = cv2.imread("images/taohua5.jpg")
y_img=[1]*10
y_img[0] = cv2.imread("images/yinghua1.jpg")
y_img[1] = cv2.imread("images/yinghua2.jpg")
y_img[2] = cv2.imread("images/yinghua3.jpg")
y_img[3] = cv2.imread("images/yinghua4.jpg")
y_img[4] = cv2.imread("images/yinghua5.jpg")
获取灰度图:
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
q_gray=[1]*10
q_gray[0] = cv2.cvtColor(q_img[0],cv2.COLOR_BGR2GRAY)
q_gray[1] = cv2.cvtColor(q_img[1],cv2.COLOR_BGR2GRAY)
q_gray[2] = cv2.cvtColor(q_img[2],cv2.COLOR_BGR2GRAY)
q_gray[3] = cv2.cvtColor(q_img[3],cv2.COLOR_BGR2GRAY)
q_gray[4] = cv2.cvtColor(q_img[4],cv2.COLOR_BGR2GRAY)
x_gray=[1]*10
x_gray[0] = cv2.cvtColor(x_img[0],cv2.COLOR_BGR2GRAY)
x_gray[1] = cv2.cvtColor(x_img[1],cv2.COLOR_BGR2GRAY)
x_gray[2] = cv2.cvtColor(x_img[2],cv2.COLOR_BGR2GRAY)
x_gray[3] = cv2.cvtColor(x_img[3],cv2.COLOR_BGR2GRAY)
x_gray[4] = cv2.cvtColor(x_img[4],cv2.COLOR_BGR2GRAY)
t_gray=[1]*10
t_gray[0] = cv2.cvtColor(t_img[0],cv2.COLOR_BGR2GRAY)
t_gray[1] = cv2.cvtColor(t_img[1],cv2.COLOR_BGR2GRAY)
t_gray[2] = cv2.cvtColor(t_img[2],cv2.COLOR_BGR2GRAY)
t_gray[3] = cv2.cvtColor(t_img[3],cv2.COLOR_BGR2GRAY)
t_gray[4] = cv2.cvtColor(t_img[4],cv2.COLOR_BGR2GRAY)
y_gray=[1]*10
y_gray[0] = cv2.cvtColor(y_img[0],cv2.COLOR_BGR2GRAY)
y_gray[1] = cv2.cvtColor(y_img[1],cv2.COLOR_BGR2GRAY)
y_gray[2] = cv2.cvtColor(y_img[2],cv2.COLOR_BGR2GRAY)
y_gray[3] = cv2.cvtColor(y_img[3],cv2.COLOR_BGR2GRAY)
y_gray[4] = cv2.cvtColor(y_img[4],cv2.COLOR_BGR2GRAY)
获取keypoints,descriptor:
detect = cv2.xfeatures2d.SIFT_create(800)
kp,des = detect.detectAndCompute(gray,None)
q_kp=[1]*10
q_des=[1]*10
q_kp[0],q_des[0] = detect.detectAndCompute(q_gray[0],None)
q_kp[1],q_des[1] = detect.detectAndCompute(q_gray[1],None)
q_kp[2],q_des[2] = detect.detectAndCompute(q_gray[2],None)
q_kp[3],q_des[3] = detect.detectAndCompute(q_gray[3],None)
q_kp[4],q_des[4] = detect.detectAndCompute(q_gray[4],None)
x_kp=[1]*10
x_des=[1]*10
x_kp[0],x_des[0] = detect.detectAndCompute(x_gray[0],None)
x_kp[1],x_des[1] = detect.detectAndCompute(x_gray[1],None)
x_kp[2],x_des[2] = detect.detectAndCompute(x_gray[2],None)
x_kp[3],x_des[3] = detect.detectAndCompute(x_gray[3],None)
x_kp[4],x_des[4] = detect.detectAndCompute(x_gray[4],None)
t_kp=[1]*10
t_des=[1]*10
t_kp[0],t_des[0] = detect.detectAndCompute(t_gray[0],None)
t_kp[1],t_des[1] = detect.detectAndCompute(t_gray[1],None)
t_kp[2],t_des[2] = detect.detectAndCompute(t_gray[2],None)
t_kp[3],t_des[3] = detect.detectAndCompute(t_gray[3],None)
t_kp[4],t_des[4] = detect.detectAndCompute(t_gray[4],None)
y_kp=[1]*10
y_des=[1]*10
y_kp[0],y_des[0] = detect.detectAndCompute(y_gray[0],None)
y_kp[1],y_des[1] = detect.detectAndCompute(y_gray[1],None)
y_kp[2],y_des[2] = detect.detectAndCompute(y_gray[2],None)
y_kp[3],y_des[3] = detect.detectAndCompute(y_gray[3],None)
y_kp[3],y_des[4] = detect.detectAndCompute(y_gray[4],None)
使用Knn匹配类进行匹配:
bf = cv2.BFMatcher()
q_matches=[1]*10
q_matches[0]= bf.knnMatch(des,q_des[0],k=2)
q_matches[1]= bf.knnMatch(des,q_des[1],k=2)
q_matches[2]= bf.knnMatch(des,q_des[2],k=2)
q_matches[3]= bf.knnMatch(des,q_des[3],k=2)
q_matches[4]= bf.knnMatch(des,q_des[4],k=2) x_matches=[1]*10
x_matches[0]= bf.knnMatch(des,x_des[0],k=2)
x_matches[1]= bf.knnMatch(des,x_des[1],k=2)
x_matches[2]= bf.knnMatch(des,x_des[2],k=2)
x_matches[3]= bf.knnMatch(des,x_des[3],k=2)
x_matches[4]= bf.knnMatch(des,x_des[4],k=2) t_matches=[1]*10
t_matches[0]= bf.knnMatch(des,t_des[0],k=2)
t_matches[1]= bf.knnMatch(des,t_des[1],k=2)
t_matches[2]= bf.knnMatch(des,t_des[2],k=2)
t_matches[3]= bf.knnMatch(des,t_des[3],k=2)
t_matches[4]= bf.knnMatch(des,t_des[4],k=2) y_matches=[1]*10
y_matches[0]= bf.knnMatch(des,y_des[0],k=2)
y_matches[1]= bf.knnMatch(des,y_des[1],k=2)
y_matches[2]= bf.knnMatch(des,y_des[2],k=2)
y_matches[3]= bf.knnMatch(des,y_des[3],k=2)
y_matches[4]= bf.knnMatch(des,y_des[4],k=2)
记录并对匹配点进行筛选:
sum1=0
sum2=0
sum3=0
sum4=0
for i in range(5):
for m,n in q_matches[i]:
if m.distance < 0.55*n.distance:
sum1=sum1+1 for i in range(5):
for m,n in x_matches[i]:
if m.distance < 0.55*n.distance:
sum2=sum2+1 for i in range(5):
for m,n in t_matches[i]:
if m.distance < 0.55*n.distance:
sum3=sum3+1 for i in range(5):
for m,n in y_matches[i]:
if m.distance < 0.55*n.distance:
sum4=sum4+1
返回结果:
if max(sum1,sum2,sum3,sum4)==sum1:
return "蔷薇" if max(sum1,sum2,sum3,sum4)==sum2:
return "杏花" if max(sum1,sum2,sum3,sum4)==sum3:
return "桃花" if max(sum1,sum2,sum3,sum4)==sum4:
return "樱花"
gui使用利用wxformbuilder+wxpython开发的简单页面
最终文件:

效果图如下:

由于图库图片较少且算法较为简单,识别率不会很高。
opencv-python下简单KNN分类识别的更多相关文章
- 有关python下二维码识别用法及识别率对比分析
最近项目中用到二维码图片识别,在python下二维码识别,目前主要有三个模块:zbar .zbarlight.zxing. 1.三个模块的用法: #-*-coding=utf-8-*- import ...
- 10分钟手把手教你运用Python实现简单的人脸识别
欲直接下载代码文件,关注我们的公众号哦!查看历史消息即可! 前言:让我的电脑认识我 我的电脑只有认识我,才配称之为我的电脑! 今天,我们用Python实现高大上的人脸识别技术! Python里,简单的 ...
- Python机器学习算法 — KNN分类
KNN简介 K最近邻(k-Nearest Neighbor,KNN)分类算法,是一个理论上比较成熟的方法,也是最简单的机器学习算法之一.KNN分类算法属于监督学习. 最简单最初级的分类器是将全部的训练 ...
- python3+opencv+tkinter开发简单的人脸识别小程序
学校里有门图像处理的课程最终需要提交一个图像处理系统, 正好之前对于opencv有些了解,就简单的写一个人脸识别小程序吧 效果图如下 笔者IDE使用Pycharm,GUI编程直接使用内置的tkinte ...
- 基于opencv+python的二维码识别
花了2天时间终于把二维码识别做出来了,不过效果一般,后面会应用在ROS辅助定位上,废话少说先上图: 具体过程参考了这位大神的博客:http://blog.csdn.net/qq_25491201/ar ...
- python实现简单kNN
注释写得很清楚了,熟悉了一下python的一些基本语法和numpy中的一些操作. from numpy import * import operator def createDataSet(): # ...
- 用python打造简单的cms识别
代码 #!/usr/bin/env python3 # coding:utf-8 #lanxing #判断代码,判断是否安装requests库 try: import requests except: ...
- Python下opencv使用笔记(一)(图像简单读取、显示与储存)
写在之前 从去年開始关注python这个软件,途中间间断断看与学过一些关于python的东西.感觉python确实是一个简单优美.easy上手的脚本编程语言,众多的第三方库使得python异常的强大. ...
- OpenCV 玩九宫格数独(二):knn 数字识别
欢迎大家关注腾讯云技术社区-博客园官方主页,我们将持续在博客园为大家推荐技术精品文章哦~ 作者:刘潇龙 前言 首先需要说明,这里所说的数字识别不是手写数字识别! 但凡对机器学习有所了解的人,相信看到数 ...
随机推荐
- 从0开始的Python学习002python的数据类型
在创建变量的时候不用声明数据类型 # 创建变量 a = 10 # 打印变量值 print(a) 结果如下: 这种感觉和Java有很大的不同,感觉python很神奇,数据的类型是python自己决定的. ...
- 我的第一个python web开发框架(26)——定制ORM(二)
弄完底层数据库操作模块后,接下来要做的是ORM的正式设计.在开始之前,我们需要思考一下怎么来设计一个ORM呢?这个类它能帮助我们处理什么样的问题?需要有哪些功能模块?怎么做到针对不同的数据库与表单进行 ...
- Autofs自动挂载探讨
Autofs介绍: mount是用来挂载文件系统的,可以在系统启动的时候挂载也可以在系统启动后挂载.对于本地固定设 备,如硬盘可以使用mount挂载:而光盘.软盘.NFS.SMB等文件系统具有动态性, ...
- chrome浏览器插件开发实例
每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code 具体步骤: 1.新建 manifest.json 文件 { "name& ...
- appium设置会话时间,可以超长时。Open Application
- python小白——进阶之路——day2天-———变量的缓存机制+自动类型转换
# ###同一文件,变量的缓存机制 ''' -->Number 部分 1.对于整型而言,-5~正无穷范围内的相同值 id一致 2.对于浮点数而言,非负数范围内的相同值 id一致 3.布尔值而言, ...
- 【原创】微服务为什么一定要用docker
引言 早在2013年的时候,docker就已经发行,然而那会还是很少人了解docker.一直到2014年,Martin Fowler提出了微服务的概念,两个不相干的技术终于走在了一起,创造了今天的辉煌 ...
- Java 200+ 面试题补充③ Dubbo 模块
昨天在我的 Java 面试粉丝群里,有一个只有一年开发经验的小伙伴只用了三天时间,就找到了一个年薪 20 万的工作,真是替他感到开心. 他的经历告诉我们:除了加强自我实战经验之外,还要努力积累自己的理 ...
- .Net Core应用框架Util介绍(一)
距离上次发文,已经过去了三年半,这几年技术更新节奏异常迅猛,.Net进入了跨平台时代,前端也被革命性的颠覆. 回顾 2015年,正当我还沉迷于JQuery + EasyUi的封装时,突然意识到技术已经 ...
- 一段c++代码实现睡眠功能
#ifdef ACL_UNIX struct timeval tv; tv.tv_sec = delay / 1000; tv.tv_usec = (suseconds_t) (delay - tv. ...