Python3学习笔记【机器学习】【k-近邻算法】【手写识别系统】

import kNN # dating program file in previous blog
from numpy import *
import operator
import os

def img2vector(filename):
    # Make the 32x32 txt file to a 1024 list
    returnVector = zeros((1,1024))
    fr = open(filename)
    for i in range(32):
        lineStr = fr.readline()
        for j in range(32):
            returnVector[0,32*i+j] = int(lineStr[j])
    return returnVector

testVector = img2vector('testDigits/0_13.txt')
print(testVector[0,0:31])
print(testVector[0,32:63])

def handwritingClassTest():
    hwLabels = []
    trainingFileList = os.listdir("trainingDigits")
    # os.listdir () : is used to return a list of files or 
    # folder names contained in the specified folder.
    LengthTFList = len(trainingFileList)
    traningMat = zeros((LengthTFList,1024))
    for i in range(LengthTFList):
        fileNameStr = trainingFileList[i]
        fileStr = fileNameStr.split('.')[0]
        # use '.' as a splitter to cut the fileName to some parts
        # give the first part to fileStr
        classNumStr = int(fileStr.split('_')[0])
        # the training file name just like '0_3.txt'
        # we need to get the object number '0' and the training data file
        # order '3'
        hwLabels.append(classNumStr)
        traningMat[i,:] = img2vector('trainingDigits/%s'%fileNameStr)
    testFileList = os.listdir('testDigits')
    errorCount = 0.0
    lengthTestFL = len(testFileList)
    for i in range(lengthTestFL):
        fileNameStr = testFileList[i]
        fileStr = fileNameStr.split('.')[0]
        classNumStr = int(fileStr.split('_')[0])
        vectorUnderTest = img2vector('testDigits/%s'%fileNameStr)
        classifiyResult = kNN.classfiy0(vectorUnderTest,traningMat,hwLabels,3)
        print('The classifier return : %d , the real answser is : %d' 
              % (classifiyResult,classNumStr))
        if (classifiyResult != classNumStr) :
            errorCount += 1.0
    print('The total error num is : %d' % errorCount)
    print('Error radio is : %f'%(errorCount/lengthTestFL))
    
handwritingClassTest()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值