opencv+KNN实现手写简单数字识别

本文介绍了使用Python和OpenCV实现手写简单数字识别的过程,通过KNN算法进行分类。尽管识别效率不高,需要相似的训练数据,但作者分享了其成果并计划优化。此外,还提出了结合Adaboost算法来提高识别速度的想法。
摘要由CSDN通过智能技术生成

学长要求做一个可视化的与数据分析的程序,就想到了这个,用了最简单的方法,其实识别效率不是很高,基本上书写要与训练数据比较相似才能识别出来,正在想办法去优化,先把目前的成果分享出来,本人是用python+opencv做的。

draw.py

相当于一个写字板,将写完字后的图片保存转为32*32

#encoding:utf-8
import cv2
import numpy as np #mouse callback function
from knn import *
ix,iy=-1,-1
#创建图像与窗口并将窗口与回调函数绑定
def in_img():
    for i in range(512):
        img[i,:]=255
    cv2.namedWindow('image')
    cv2.setMouseCallback('image',draw_circle)
    while(1):
        cv2.imshow('image',img)
        if cv2.waitKey(20)& 0xFF == ord('q'):
            cv2.imwrite( '1.jpg',img)
            break
    cv2.destroyAllWindows()
def draw_circle(event,x,y,flags,param):
    global ix,iy,drawing
    if event==cv2.EVENT_LBUTTONDOWN:
        drawing=True
        ix,iy=x,y
    elif event==cv2.EVENT_MOUSEMOVE and flags==cv2.EVENT_FLAG_LBUTTON:
        if drawing==True:
            cv2.circle(img,(x,y),30,(0,0,0),-1)
    elif event==cv2.EVENT_LBUTTONUP:
        drawing==False
def read_image():
    img1 = cv2.imread('1.jpg', cv2.IMREAD_GRAYSCALE)
    r
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Sure, 我可以回答你的问题。以下是一个基于 OpenCVKNN手写数字识别代码示例: ```python import cv2 import numpy as np # Load the dataset for training digits = cv2.imread('digits.png',0) digits = cv2.resize(digits, (1000, 2000)) # Split into individual digit images rows = np.vsplit(digits,50) cells = [] for row in rows: row_cells = np.hsplit(row,50) for cell in row_cells: cell = cell.flatten() cells.append(cell) X = np.array(cells, np.float32) # Create labels for each digit y = np.repeat(np.arange(10),250) # Train a KNN model on the dataset knn = cv2.ml.KNearest_create() knn.train(X, cv2.ml.ROW_SAMPLE, y) # Load the image and preprocess it for prediction img = cv2.imread('test.png',0) img = cv2.resize(img, (28,28)) img = img.reshape(-1,28*28) img = np.float32(img) # Use the KNN model to predict the digit ret,result,neighbours,dist = knn.findNearest(img,k=5) # Print the predicted digit print(int(result[0][0])) ``` 在上述示例中,我们首先加载包含许多手写数字的数据集。我们将数据集拆分为50x50个单元格,并将每个单元格转换为一维向量。然后我们创建标签,其中每个标签对应于一个数字,并使用KNN模型进行训练。我们然后加载一个包含手写数字的测试图像,预处理图像以适合KNN模型,使用KNN模型预测数字,并打印结果。 注意,在实际应用中,您可能需要对识别准确性、计算效率和对错误处理的能力进行更多的优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值