這篇文章主要介紹了從TensorFlow中mnist數(shù)據(jù)集導(dǎo)出手寫(xiě)體數(shù)字圖片的案例,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
專(zhuān)注于為中小企業(yè)提供成都做網(wǎng)站、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)金林免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上1000+企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。mnist數(shù)據(jù)集是一個(gè)數(shù)字手寫(xiě)體圖片庫(kù),但它的存儲(chǔ)格式并非常見(jiàn)的圖片格式,所有的圖片都集中保存在四個(gè)擴(kuò)展名為idx3-ubyte的二進(jìn)制文件。
如果我們想要知道大名鼎鼎的mnist手寫(xiě)體數(shù)字都長(zhǎng)什么樣子,就需要從mnist數(shù)據(jù)集中導(dǎo)出手寫(xiě)體數(shù)字圖片。了解這些手寫(xiě)體的總體形狀,也有助于加深我們對(duì)TensorFlow入門(mén)課程的理解。
下面先給出通過(guò)TensorFlow api接口導(dǎo)出mnist手寫(xiě)體數(shù)字圖片的python代碼,再對(duì)代碼進(jìn)行分析。代碼在win7下測(cè)試通過(guò),linux環(huán)境也可以參考本處代碼。
#!/usr/bin/python3.5 # -*- coding: utf-8 -*- import os import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_data from PIL import Image # 聲明圖片寬高 rows = 28 cols = 28 # 要提取的圖片數(shù)量 images_to_extract = 8000 # 當(dāng)前路徑下的保存目錄 save_dir = "./mnist_digits_images" # 讀入mnist數(shù)據(jù) mnist = input_data.read_data_sets("MNIST_data/", one_hot=False) # 創(chuàng)建會(huì)話 sess = tf.Session() # 獲取圖片總數(shù) shape = sess.run(tf.shape(mnist.train.images)) images_count = shape[0] pixels_per_image = shape[1] # 獲取標(biāo)簽總數(shù) shape = sess.run(tf.shape(mnist.train.labels)) labels_count = shape[0] # mnist.train.labels是一個(gè)二維張量,為便于后續(xù)生成數(shù)字圖片目錄名,有必要一維化(后來(lái)發(fā)現(xiàn)只要把數(shù)據(jù)集的one_hot屬性設(shè)為False,mnist.train.labels本身就是一維) #labels = sess.run(tf.argmax(mnist.train.labels, 1)) labels = mnist.train.labels # 檢查數(shù)據(jù)集是否符合預(yù)期格式 if (images_count == labels_count) and (shape.size == 1): print ("數(shù)據(jù)集總共包含 %s 張圖片,和 %s 個(gè)標(biāo)簽" % (images_count, labels_count)) print ("每張圖片包含 %s 個(gè)像素" % (pixels_per_image)) print ("數(shù)據(jù)類(lèi)型:%s" % (mnist.train.images.dtype)) # mnist圖像數(shù)據(jù)的數(shù)值范圍是[0,1],需要擴(kuò)展到[0,255],以便于人眼觀看 if mnist.train.images.dtype == "float32": print ("準(zhǔn)備將數(shù)據(jù)類(lèi)型從[0,1]轉(zhuǎn)為binary[0,255]...") for i in range(0,images_to_extract): for n in range(pixels_per_image): if mnist.train.images[i][n] != 0: mnist.train.images[i][n] = 255 # 由于數(shù)據(jù)集圖片數(shù)量龐大,轉(zhuǎn)換可能要花不少時(shí)間,有必要打印轉(zhuǎn)換進(jìn)度 if ((i+1)%50) == 0: print ("圖像浮點(diǎn)數(shù)值擴(kuò)展進(jìn)度:已轉(zhuǎn)換 %s 張,共需轉(zhuǎn)換 %s 張" % (i+1, images_to_extract)) # 創(chuàng)建數(shù)字圖片的保存目錄 for i in range(10): dir = "%s/%s/" % (save_dir,i) if not os.path.exists(dir): print ("目錄 ""%s"" 不存在!自動(dòng)創(chuàng)建該目錄..." % dir) os.makedirs(dir) # 通過(guò)python圖片處理庫(kù),生成圖片 indices = [0 for x in range(0, 10)] for i in range(0,images_to_extract): img = Image.new("L",(cols,rows)) for m in range(rows): for n in range(cols): img.putpixel((n,m), int(mnist.train.images[i][n+m*cols])) # 根據(jù)圖片所代表的數(shù)字label生成對(duì)應(yīng)的保存路徑 digit = labels[i] path = "%s/%s/%s.bmp" % (save_dir, labels[i], indices[digit]) indices[digit] += 1 img.save(path) # 由于數(shù)據(jù)集圖片數(shù)量龐大,保存過(guò)程可能要花不少時(shí)間,有必要打印保存進(jìn)度 if ((i+1)%50) == 0: print ("圖片保存進(jìn)度:已保存 %s 張,共需保存 %s 張" % (i+1, images_to_extract)) else: print ("圖片數(shù)量和標(biāo)簽數(shù)量不一致!")
上述代碼的實(shí)現(xiàn)思路如下:
1.讀入mnist手寫(xiě)體數(shù)據(jù);
2.把數(shù)據(jù)的值從[0,1]浮點(diǎn)范圍轉(zhuǎn)化為黑白格式(背景為0-黑色,前景為255-白色);
3.根據(jù)mnist.train.labels的內(nèi)容,生成數(shù)字索引,也就是建立每一張圖片和其所代表數(shù)字的關(guān)聯(lián),由此創(chuàng)建對(duì)應(yīng)的保存目錄;
4.循環(huán)遍歷mnist.train.images,把每張圖片的像素?cái)?shù)據(jù)賦值給python圖片處理庫(kù)PIL的Image類(lèi)實(shí)例,再調(diào)用Image類(lèi)的save方法把圖片保存在第3步驟中創(chuàng)建的對(duì)應(yīng)目錄。
在運(yùn)行上述代碼之前,你需要確保本地已經(jīng)安裝python的圖片處理庫(kù)PIL,pip安裝命令如下:
pip3 install Pillow
或 pip install Pillow,取決于你的pip版本。
上述python代碼運(yùn)行后,在當(dāng)前目錄下會(huì)生成mnist_digits_images目錄,在該目錄下,可以看到如下內(nèi)容:
可以看到,我們成功地生成了黑底白字的數(shù)字圖片。
如果仔細(xì)觀察這些圖片,會(huì)看到一些肉眼也難以分辨的數(shù)字,譬如:
上面這幾個(gè)數(shù)字是2。想不到吧?
下面這兩個(gè)是5(看起來(lái)更像6):
這個(gè)是7:(7長(zhǎng)這樣?有句MMP不知當(dāng)講不當(dāng)講)
猜猜下面這個(gè)是什么:
這是大寫(xiě)的L?不是。
有點(diǎn)像1,是1嗎?也不是。
倒立拉粑的7?sorry,又猜錯(cuò)了。
實(shí)話告訴您,它是2!一開(kāi)始我也是不相信的,知道真相的那一刻我下巴差點(diǎn)掉下來(lái)!
這些手寫(xiě)圖片,一般人用肉眼觀察,識(shí)別率能達(dá)到98%就不錯(cuò)了,但是通過(guò)TensorFlow搭建的卷積神經(jīng)網(wǎng)絡(luò)識(shí)別率可以達(dá)到99%,非常地神奇!
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“從TensorFlow中mnist數(shù)據(jù)集導(dǎo)出手寫(xiě)體數(shù)字圖片的案例”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
網(wǎng)頁(yè)標(biāo)題:從TensorFlow中mnist數(shù)據(jù)集導(dǎo)出手寫(xiě)體數(shù)字圖片的案例-創(chuàng)新互聯(lián)
標(biāo)題網(wǎng)址:http://aaarwkj.com/article2/dihiic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、定制網(wǎng)站、網(wǎng)站營(yíng)銷(xiāo)、云服務(wù)器、網(wǎng)站導(dǎo)航、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容