python MNIST手写识别数据调用API的方法


Posted in Python onAugust 08, 2018

MNIST数据集比较小,一般入门机器学习都会采用这个数据集来训练

下载地址:yann.lecun.com/exdb/mnist/

有4个有用的文件:
train-images-idx3-ubyte: training set images
train-labels-idx1-ubyte: training set labels
t10k-images-idx3-ubyte: test set images
t10k-labels-idx1-ubyte: test set labels

The training set contains 60000 examples, and the test set 10000 examples. 数据集存储是用binary file存储的,黑白图片。

下面给出load数据集的代码:

import os
import struct
import numpy as np
import matplotlib.pyplot as plt

def load_mnist():
  '''
  Load mnist data
  http://yann.lecun.com/exdb/mnist/

  60000 training examples
  10000 test sets

  Arguments:
    kind: 'train' or 'test', string charater input with a default value 'train'

  Return:
    xxx_images: n*m array, n is the sample count, m is the feature number which is 28*28
    xxx_labels: class labels for each image, (0-9)
  '''

  root_path = '/home/cc/deep_learning/data_sets/mnist'

  train_labels_path = os.path.join(root_path, 'train-labels.idx1-ubyte')
  train_images_path = os.path.join(root_path, 'train-images.idx3-ubyte')

  test_labels_path = os.path.join(root_path, 't10k-labels.idx1-ubyte')
  test_images_path = os.path.join(root_path, 't10k-images.idx3-ubyte')

  with open(train_labels_path, 'rb') as lpath:
    # '>' denotes bigedian
    # 'I' denotes unsigned char
    magic, n = struct.unpack('>II', lpath.read(8))
    #loaded = np.fromfile(lpath, dtype = np.uint8)
    train_labels = np.fromfile(lpath, dtype = np.uint8).astype(np.float)

  with open(train_images_path, 'rb') as ipath:
    magic, num, rows, cols = struct.unpack('>IIII', ipath.read(16))
    loaded = np.fromfile(train_images_path, dtype = np.uint8)
    # images start from the 16th bytes
    train_images = loaded[16:].reshape(len(train_labels), 784).astype(np.float)

  with open(test_labels_path, 'rb') as lpath:
    # '>' denotes bigedian
    # 'I' denotes unsigned char
    magic, n = struct.unpack('>II', lpath.read(8))
    #loaded = np.fromfile(lpath, dtype = np.uint8)
    test_labels = np.fromfile(lpath, dtype = np.uint8).astype(np.float)

  with open(test_images_path, 'rb') as ipath:
    magic, num, rows, cols = struct.unpack('>IIII', ipath.read(16))
    loaded = np.fromfile(test_images_path, dtype = np.uint8)
    # images start from the 16th bytes
    test_images = loaded[16:].reshape(len(test_labels), 784)  

  return train_images, train_labels, test_images, test_labels

再看看图片集是什么样的:

def test_mnist_data():
  '''
  Just to check the data

  Argument:
    none

  Return:
    none
  '''
  train_images, train_labels, test_images, test_labels = load_mnist()
  fig, ax = plt.subplots(nrows = 2, ncols = 5, sharex = True, sharey = True)
  ax =ax.flatten()
  for i in range(10):
    img = train_images[i][:].reshape(28, 28)
    ax[i].imshow(img, cmap = 'Greys', interpolation = 'nearest')
    print('corresponding labels = %d' %train_labels[i])

if __name__ == '__main__':
  test_mnist_data()

跑出的结果如下:

python MNIST手写识别数据调用API的方法

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

Python 相关文章推荐
python的几种开发工具介绍
Mar 07 Python
python如何实现excel数据添加到mongodb
Jul 30 Python
Python矩阵常见运算操作实例总结
Sep 29 Python
Python查看微信撤回消息代码
Jun 07 Python
Python实现数据可视化看如何监控你的爬虫状态【推荐】
Aug 10 Python
Python模块的加载讲解
Jan 15 Python
Python3.5基础之NumPy模块的使用图文与实例详解
Apr 24 Python
解决Python正则表达式匹配反斜杠''\''问题
Jul 17 Python
Django rstful登陆认证并检查session是否过期代码实例
Aug 13 Python
Pythonic版二分查找实现过程原理解析
Aug 11 Python
Django crontab定时任务模块操作方法解析
Sep 10 Python
python 模拟在天空中放风筝的示例代码
Apr 21 Python
python实现屏保计时器的示例代码
Aug 08 #Python
详解Python 装饰器执行顺序迷思
Aug 08 #Python
python Flask 装饰器顺序问题解决
Aug 08 #Python
Python BS4库的安装与使用详解
Aug 08 #Python
python特性语法之遍历、公共方法、引用
Aug 08 #Python
用Python shell简化开发
Aug 08 #Python
在Python中使用gRPC的方法示例
Aug 08 #Python
You might like
PHP使用mkdir创建多级目录的方法
2015/12/22 PHP
PHP中for循环与foreach的区别
2017/03/06 PHP
完美的php分页类
2017/10/24 PHP
jquery解析JSON数据示例代码
2014/03/17 Javascript
js跨域问题浅析及解决方法优缺点对比
2014/11/08 Javascript
jquery实现用户打分评分特效
2015/05/28 Javascript
AngularJS基础 ng-selected 指令简单示例
2016/08/03 Javascript
AngularJS使用自定义指令替代ng-repeat的方法
2016/09/17 Javascript
Vue2.0组件间数据传递示例
2017/03/07 Javascript
如何在AngularJs中调用第三方插件库
2017/05/21 Javascript
Vuex 使用 v-model 配合 state的方法
2018/11/13 Javascript
vue使用Google地图的实现示例代码
2018/12/19 Javascript
150行Node.js实现的dns代理工具
2019/08/02 Javascript
在vant中使用时间选择器和popup弹出层的操作
2020/11/04 Javascript
[01:05:56]2018DOTA2亚洲邀请赛3月29日 小组赛A组 Newbee VS VG
2018/03/30 DOTA
Python文件右键找不到IDLE打开项解决办法
2015/06/08 Python
在python3.5中使用OpenCV的实例讲解
2018/04/02 Python
对Python中列表和数组的赋值,浅拷贝和深拷贝的实例讲解
2018/06/28 Python
Python中文件的写入读取以及附加文字方法
2019/01/23 Python
python实现弹窗祝福效果
2019/04/07 Python
python 进程的几种创建方式详解
2019/08/29 Python
Python django搭建layui提交表单,表格,图标的实例
2019/11/18 Python
python文件和文件夹复制函数
2020/02/07 Python
keras导入weights方式
2020/06/12 Python
python等待10秒执行下一命令的方法
2020/07/19 Python
HTML5实现表单自动验证功能实例代码
2017/01/11 HTML / CSS
德国电子产品购物网站:TechInTheBasket德国
2018/12/07 全球购物
会计岗位职责
2013/11/08 职场文书
机械电子工程毕业生自荐信
2013/11/23 职场文书
护理专业毕业生自荐信
2014/06/15 职场文书
社会实践的活动方案
2014/08/22 职场文书
银行贷款委托书范本
2014/10/11 职场文书
八一建军节慰问信
2015/02/14 职场文书
肖申克的救赎观后感
2015/06/02 职场文书
解决SpringCloud Feign传对象参数调用失败的问题
2021/06/23 Java/Android
python 学习GCN图卷积神经网络
2022/05/11 Python