欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用NumPy讀取MNIST數(shù)據(jù)的實現(xiàn)代碼示例

 更新時間:2019年11月20日 14:20:34   作者:justidle  
這篇文章主要介紹了使用NumPy讀取MNIST數(shù)據(jù)的實現(xiàn)代碼示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

NumPy

什么是NumPy

NumPy是 Python 語言的一個擴展程序庫,支持大量的維度數(shù)組與矩陣運算,此外也針對數(shù)組運算提供大量的數(shù)學函數(shù)庫。主頁為https://numpy.org/。

安裝NumPy

使用pip工具來安裝。

python -m pip install numpy

使用NumPy讀取mnist數(shù)據(jù)

如果直接從網(wǎng)絡上讀取mnist數(shù)據(jù),恭喜你,目前國內(nèi)基本需要一個小時以上。所以建議預先下載mnist數(shù)據(jù)包。

工作環(huán)境

當前我的工作環(huán)境如下:Win10 + Anaconda。使用Spyder4做為IDE。Anaconda的安裝可以參考我的blog。

將數(shù)據(jù)放置到指定目錄

下圖是我當前的工作目錄環(huán)境,因此在C:\Users\sus20\.spyder-py3-dev目錄下,建立子目錄minist。如下圖所示:

將下載好的四個gz文件拷貝到這個目錄下,并將這四個gz文件解壓。如下圖所示:

使用NumPy讀取MNIST

load_mnist 函數(shù)返回兩個數(shù)組,第一個是一個 n * m 維的 NumPy array(images),這里的 n 是樣本行數(shù),m 是特征列數(shù)。訓練數(shù)據(jù)集包含 60,000 個樣本,測試數(shù)據(jù)集包含 10,000 樣本。

在 MNIST 數(shù)據(jù)集中的每張圖片由 28 * 28 個像素點構成,每個像素點用一個灰度值表示。在這里,我們將 28 * 28 的像素展開為一個一維的行向量,這些行向量就是圖片數(shù)組里的行(每行 784 個值, 或者說每行就是代表了一張圖片)。

load_mnist 函數(shù)返回的第二個數(shù)組(labels) 包含了相應的目標變量,也就是手寫數(shù)字的類標簽(整數(shù) 0-9)。

import os
import struct
import numpy as np
 
def load_mnist(path, kind='train'):
  """Load MNIST data from `path`"""
  labels_path = os.path.join(path,'%s-labels-idx1-ubyte'% kind)
  
  images_path = os.path.join(path,'%s-images-idx3-ubyte'% kind)
  
  with open(labels_path, 'rb') as lbpath:
    magic, n = struct.unpack('>II',lbpath.read(8))
    labels = np.fromfile(lbpath,dtype=np.uint8)
  #讀入magic是一個文件協(xié)議的描述,也是調(diào)用fromfile 方法將字節(jié)讀入NumPy的array之前在文件緩沖中的item數(shù)(n). 
 
  with open(images_path, 'rb') as imgpath:
    magic, num, rows, cols = struct.unpack('>IIII',imgpath.read(16))
    images = np.fromfile(imgpath,dtype=np.uint8).reshape(len(labels), 784)
  return images, labels
 
print(load_mnist("minst_data"))

運行代碼,將得到如下圖結果,說明我們已經(jīng)正確的從本地讀取MNIST數(shù)據(jù)集。

下一步,我們要開始使用TensorFlow讀取MNIST數(shù)據(jù)集。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 簡單了解Django ORM常用字段類型及參數(shù)配置

    簡單了解Django ORM常用字段類型及參數(shù)配置

    這篇文章主要介紹了簡單了解Django ORM常用字段類型及參數(shù)配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01
  • pytorch模型的保存加載與續(xù)訓練詳解

    pytorch模型的保存加載與續(xù)訓練詳解

    這篇文章主要為大家介紹了pytorch模型的保存加載與續(xù)訓練詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • python中字符串數(shù)組逆序排列方法總結

    python中字符串數(shù)組逆序排列方法總結

    在本篇文章里小編給大家整理了關于python中字符串數(shù)組如何逆序排列的相關知識點,需要的朋友們學習下。
    2019-06-06
  • python中的IO流使用解讀

    python中的IO流使用解讀

    這篇文章主要介紹了python中的IO流使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python 實現(xiàn)將Numpy數(shù)組保存為圖像

    python 實現(xiàn)將Numpy數(shù)組保存為圖像

    今天小編就為大家分享一篇python 實現(xiàn)將Numpy數(shù)組保存為圖像,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • 基于python 微信小程序之獲取已存在模板消息列表

    基于python 微信小程序之獲取已存在模板消息列表

    這篇文章主要介紹了基于python 微信小程序之獲取已存在模板消息列表的相關知識,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • 使用python解析MDX詞典數(shù)據(jù)并保存為Excel文件

    使用python解析MDX詞典數(shù)據(jù)并保存為Excel文件

    MDX(Mobile Dictionary eXchange)是一種常見的詞典文件格式,通常用于在移動設備和電腦之間共享辭典數(shù)據(jù),本文深入探討了從MDX詞典數(shù)據(jù)提取、處理到最終保存為Excel文件的全過程,需要的朋友可以參考下
    2023-12-12
  • python中的np.round()函數(shù)示例詳解

    python中的np.round()函數(shù)示例詳解

    np.round()是NumPy庫中的一個函數(shù),用于對數(shù)組或單個數(shù)值進行四舍五入,該函數(shù)返回一個與輸入類型相同的數(shù)組或數(shù)值,并可以通過可選的參數(shù)來指定保留的小數(shù)位數(shù),這篇文章主要介紹了python中的np.round()函數(shù),需要的朋友可以參考下
    2024-06-06
  • python 字符串split的用法分享

    python 字符串split的用法分享

    python 字符串的split方法是用的頻率還是比較多的。比如我們需要存儲一個很長的數(shù)據(jù),并且按照有結構的方法存儲,方便以后取數(shù)據(jù)進行處理。當然可以用json的形式。但是也可以把數(shù)據(jù)存儲到一個字段里面,然后有某種標示符來分割
    2013-03-03
  • Anaconda環(huán)境變量的配置圖文詳解

    Anaconda環(huán)境變量的配置圖文詳解

    Anaconda指的是一個開源的Python發(fā)行版本,其包含了conda、Python等180多個科學包及其依賴項,下面這篇文章主要給大家介紹了關于Anaconda環(huán)境變量配置的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08

最新評論