MNIST数据可视化

代码

import numpy as np
import struct
from scipy.misc import imsave
from PIL import Image

'''
mnist数据格式
'''

def loadImageSet(filename):
    # 读取二进制文件
    binfile = open(filename, 'rb')
    buffers = binfile.read()

    # 取前4个整数,返回一个元组
    head = struct.unpack_from('>IIII', buffers, 0)
    magicNum = head[0]
    imgNum = head[1]
    width = head[2]
    height = head[3]

    # 取data数据,返回一个元组
    offset = struct.calcsize('>IIII')  # 定位到data开始的位置

    bits = imgNum * width * height  # data一共有60000*28*28个像素值
    bitsString = '>' + str(bits) + 'B'  # fmt格式:'>47040000B'

    imgs = struct.unpack_from(bitsString, buffers, offset)

    binfile.close()

   # imgs = np.reshape(imgs, [imgNum, width * height])  # reshape为[60000,784]型数组
    imgs = np.array(imgs).astype(np.uint8).reshape(imgNum, 1, width, height)
    return imgs, head

if __name__=="__main__":
    file1 = './mnist/train-images.idx3-ubyte'
    imgs, data_head = loadImageSet(file1)
    #测试,输出第一张图,没有用for导出全部图像
    img = Image.fromarray(imgs[1, 0, 0:28, 0:28])
    img.save("mnist.jpg")
mnist.jpg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值