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