Tensorflow模型實(shí)現(xiàn)預(yù)測(cè)或識(shí)別單張圖片
利用Tensorflow訓(xùn)練好的模型,圖片進(jìn)行預(yù)測(cè)和識(shí)別,并輸出相應(yīng)的標(biāo)簽和預(yù)測(cè)概率。
如果想要多張圖片,可以進(jìn)行批次加載和預(yù)測(cè),這里僅用單張圖片進(jìn)行演示。
模型文件:
預(yù)測(cè)圖片:
這里直接貼代碼,都有注釋,應(yīng)該很好理解
import tensorflow as tf import inference image_size = 128 # 輸入層圖片大小 # 模型保存的路徑和文件名 MODEL_SAVE_PATH = "model/" MODEL_NAME = "model.ckpt" # 加載需要預(yù)測(cè)的圖片 image_data = tf.gfile.FastGFile("./data/test/d.png", 'rb').read() # 將圖片格式轉(zhuǎn)換成我們所需要的矩陣格式,第二個(gè)參數(shù)為1,代表1維 decode_image = tf.image.decode_png(image_data, 1) # 再把數(shù)據(jù)格式轉(zhuǎn)換成能運(yùn)算的float32 decode_image = tf.image.convert_image_dtype(decode_image, tf.float32) # 轉(zhuǎn)換成指定的輸入格式形狀 image = tf.reshape(decode_image, [-1, image_size, image_size, 1]) # 定義預(yù)測(cè)結(jié)果為logit值最大的分類,這里是前向傳播算法,也就是卷積層、池化層、全連接層那部分 test_logit = inference.inference(image, train=False, regularizer=None) # 利用softmax來(lái)獲取概率 probabilities = tf.nn.softmax(test_logit) # 獲取最大概率的標(biāo)簽位置 correct_prediction = tf.argmax(test_logit, 1) # 定義Savar類 saver = tf.train.Saver() with tf.Session() as sess: sess.run((tf.global_variables_initializer(), tf.local_variables_initializer())) # 加載檢查點(diǎn)狀態(tài),這里會(huì)獲取最新訓(xùn)練好的模型 ckpt = tf.train.get_checkpoint_state(MODEL_SAVE_PATH) if ckpt and ckpt.model_checkpoint_path: # 加載模型和訓(xùn)練好的參數(shù) saver.restore(sess, ckpt.model_checkpoint_path) print("加載模型成功:" + ckpt.model_checkpoint_path) # 通過(guò)文件名得到模型保存時(shí)迭代的輪數(shù).格式:model.ckpt-6000.data-00000-of-00001 global_step = ckpt.model_checkpoint_path.split('/')[-1].split('-')[-1] # 獲取預(yù)測(cè)結(jié)果 probabilities, label = sess.run([probabilities, correct_prediction]) # 獲取此標(biāo)簽的概率 probability = probabilities[0][label] print("After %s training step(s),validation label = %d, has %g probability" % (global_step, label, probability)) else: print("模型加載失??!" + ckpt.model_checkpoint_path)
運(yùn)行輸出結(jié)果:
(標(biāo)簽為3,概率為0.984478)
標(biāo)簽字典:
3對(duì)應(yīng)小寫(xiě)d,識(shí)別正確。
其他的圖片的預(yù)測(cè)結(jié)果:
預(yù)測(cè)圖片1:
標(biāo)簽字典:
圖片1,識(shí)別結(jié)果為1,可能概率0.993034
識(shí)別結(jié)果還是挺好看的,不知道是不是過(guò)擬合了,還是迭代次數(shù)不夠多,還需要調(diào)整調(diào)整。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python+requests接口自動(dòng)化框架的實(shí)現(xiàn)
這篇文章主要介紹了python+requests接口自動(dòng)化框架的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08pytorch中的reshape()、view()、nn.flatten()和flatten()使用
這篇文章主要介紹了pytorch中的reshape()、view()、nn.flatten()和flatten()使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08python從網(wǎng)絡(luò)讀取圖片并直接進(jìn)行處理的方法
這篇文章主要介紹了python從網(wǎng)絡(luò)讀取圖片并直接進(jìn)行處理的方法,涉及cStringIO模塊模擬本地文件的使用技巧,需要的朋友可以參考下2015-05-05pandas學(xué)習(xí)之df.fillna的具體使用
本文主要介紹了pandas學(xué)習(xí)之df.fillna的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08Python如何運(yùn)用pyaudio庫(kù)去做一個(gè)固定采樣率音頻錄制器
這篇文章主要介紹了Python如何運(yùn)用pyaudio庫(kù)去做一個(gè)固定采樣率音頻錄制器問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05Python中tkinter無(wú)法同時(shí)顯示多個(gè)image的解決方法及pack與place解析
這篇文章主要介紹了Python中tkinter無(wú)法同時(shí)顯示多個(gè)image的解決方法及pack與place解析,本文給大家分享問(wèn)題原因解析及解決方案,需要的朋友可以參考下2023-02-02python判定文件目錄是否存在及創(chuàng)建多層目錄
這篇文章主要介紹了python判定文件目錄是否存在及創(chuàng)建多層目錄,文章通過(guò)os模塊、try語(yǔ)句、pathlib模塊善終模塊展開(kāi)詳細(xì)的內(nèi)容,感興趣的朋友可以參考一下2022-06-06