机器学习python实战之手写数字识别


Posted in Python onNovember 01, 2017

看了上一篇内容之后,相信对K近邻算法有了一个清晰的认识,今天的内容——手写数字识别是对上一篇内容的延续,这里也是为了自己能更熟练的掌握k-NN算法。

我们有大约2000个训练样本和1000个左右测试样本,训练样本所在的文件夹是trainingDigits,测试样本所在的文件夹是testDigits。文本文件中是0~9的数字,但是是用二值图表示出来的,如图。我们要做的就是使用训练样本训练模型,并用测试样本来检测模型的性能。

机器学习python实战之手写数字识别

首先,我们需要将文本文件中的内容转化为向量,因为图片大小是32*32,所以我们可以将其转化为1*1024的向量。具体代码实现如下:

def img2vector(filename):
  imgVec = zeros((1,1024))
  file = open(filename)
  for i in range(32):
    lines = file.readline()
    for j in range(32):
      imgVec[0,32*i+j] = lines[j]
  return imgVec

实现了图片到向量的转化之后,我们就可以对测试文件中的内容进行识别了。这里的识别我们可以使用上一篇中的自定义函数classify0,这个函数的第一个参数是测试向量,第二个参数是训练数据集,第三个参数是训练集的标签。所以,我们首先需要将训练数据集转化为(1934*1024)的矩阵,1934这里是训练集的组数即trainingDigits目录下的文件数,其对应的标签转化为(1*1934)的向量。之后要编写的代码就是对测试数据集中的每个文本文件进行识别,也就是需要将每个文件都转化成一个(1*1024)的向量,再传入classify0函数的第一个形参。整体代码如下:

def handWriteNumClassTest():
  NumLabels = []
  TrainingDirfile = listdir(r'D:\ipython\num_recognize\trainingDigits')#文件目录
  L = len(TrainingDirfile)  #该目录中有多少文件
  TrainMat = zeros((L,1024))
  for i in range(L):
    file_n = TrainingDirfile[i]
    fileName = file_n.split('.')[0]
    ClassName = int(file_n.split('_')[0])
    NumLabels.append(ClassName)
    TrainMat[i,:] = img2vector(r'D:\ipython\num_recognize\trainingDigits\%s'%file_n)
  TestfileDir = listdir(r'D:\ipython\num_recognize\testDigits')
  error_cnt = 0.0
  M = len(TestfileDir)
  for j in range(M):
    Testfile = TestfileDir[j]
    TestfileName = Testfile.split('.')[0]
    TestClassName = int(Testfile.split('_')[0])
    TestVector = img2vector(r'D:\ipython\num_recognize\testDigits\%s'%Testfile)
    result = classify0(TestVector,TrainMat,NumLabels,3)
    print('the result is %d,the real answer is %d\n'%(result,TestClassName))
    if result!=TestClassName:
      error_cnt+=1
  print('the total num of errors is %f\n'%error_cnt)
  print('the error rate is %f\n'%(error_cnt/float(M)))

这里需要首先导入listdir方法,from os import listdir,它可以列出给定目录的文件名。对于测试的每个文件,如果识别的分类结果跟真实结果不一样,则错误数+1,最终用错误数/测试总数 来表示该模型的性能。下面给出结果

机器学习python实战之手写数字识别

这里测试的总共946个项目中,一共有10个出现了错误,出错率为1%,这个性能还是可以接受的。有了上一篇内容的理解,这篇就简单多了吧!

训练数据集和测试集文件下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python获取当前用户的主目录路径方法(推荐)
Jan 12 Python
用Django实现一个可运行的区块链应用
Mar 08 Python
Python+Pandas 获取数据库并加入DataFrame的实例
Jul 25 Python
对python函数签名的方法详解
Jan 22 Python
Tensorflow分类器项目自定义数据读入的实现
Feb 05 Python
Python人工智能之路 jieba gensim 最好别分家之最简单的相似度实现
Aug 13 Python
python FTP批量下载/删除/上传实例
Dec 22 Python
pyinstaller将含有多个py文件的python程序做成exe
Apr 29 Python
tensorflow模型的save与restore,及checkpoint中读取变量方式
May 26 Python
python中return不返回值的问题解析
Jul 22 Python
pandas实现导出数据的四种方式
Dec 13 Python
Python中的嵌套循环详情
Mar 23 Python
Python定时器实例代码
Nov 01 #Python
机器学习python实战之决策树
Nov 01 #Python
详解Python开发中如何使用Hook技巧
Nov 01 #Python
python利用标准库如何获取本地IP示例详解
Nov 01 #Python
你眼中的Python大牛 应该都有这份书单
Oct 31 #Python
Python生成数字图片代码分享
Oct 31 #Python
python使用标准库根据进程名如何获取进程的pid详解
Oct 31 #Python
You might like
php生成缩略图的类代码
2008/10/02 PHP
PHP 页面跳转到另一个页面的多种方法方法总结
2009/07/07 PHP
php用数组返回无限分类的列表数据的代码
2010/08/08 PHP
解析thinkphp中的M()与D()方法的区别
2013/06/22 PHP
ThinkPHP3.1新特性之命名范围的使用
2014/06/19 PHP
使用Codeigniter重写insert的方法(推荐)
2017/03/23 PHP
php封装db类连接sqlite3数据库的方法实例
2017/12/19 PHP
PHP单例模式应用示例【多次连接数据库只实例化一次】
2018/12/18 PHP
jQuery 选择器、DOM操作、事件、动画
2010/11/25 Javascript
jqGrid jQuery 表格插件测试代码
2011/08/23 Javascript
JavaScript实现生成GUID(全局统一标识符)
2014/09/05 Javascript
node.js中的fs.writeFile方法使用说明
2014/12/14 Javascript
jQuery使用append在html元素后同时添加多项内容的方法
2015/03/26 Javascript
js事件源window.event.srcElement兼容性写法(详解)
2016/11/25 Javascript
react性能优化达到最大化的方法 immutable.js使用的必要性
2017/03/09 Javascript
BootStrap模态框不垂直居中的解决方法
2017/10/19 Javascript
Node.js实现简单的爬取的示例代码
2019/06/25 Javascript
JavaScript享元模式原理与用法实例详解
2020/03/09 Javascript
vue从后台渲染文章列表以及根据id跳转文章详情详解
2020/12/14 Vue.js
[46:10]2014 DOTA2国际邀请赛中国区预选赛 CnB VS HGT
2014/05/21 DOTA
[02:41]2015国际邀请赛中国区预选赛观战指南
2015/05/20 DOTA
Python学习笔记基本数据结构之序列类型list tuple range用法分析
2019/06/08 Python
安装好Pycharm后如何配置Python解释器简易教程
2019/06/28 Python
Pytorch自己加载单通道图片用作数据集训练的实例
2020/01/18 Python
Django框架models使用group by详解
2020/03/11 Python
python中format函数如何使用
2020/06/22 Python
Keras构建神经网络踩坑(解决model.predict预测值全为0.0的问题)
2020/07/07 Python
python实现AdaBoost算法的示例
2020/10/03 Python
css3 自定义字体font-face使用介绍
2014/05/14 HTML / CSS
机电专业体育教师求职信
2013/09/21 职场文书
小学生常见病防治方案
2014/06/06 职场文书
自我介绍演讲稿范文
2014/08/21 职场文书
小学六一儿童节活动方案
2014/08/27 职场文书
办理护照工作证明
2014/10/10 职场文书
党员作风建设整改方案
2014/10/27 职场文书
退休欢送会致辞
2015/07/31 职场文书