TensorFlow卷積神經(jīng)網(wǎng)絡(luò)之使用訓(xùn)練好的模型識(shí)別貓狗圖片
本文是Python通過TensorFlow卷積神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)貓狗識(shí)別的姊妹篇,是加載上一篇訓(xùn)練好的模型,進(jìn)行貓狗識(shí)別
本文邏輯:
- 我從網(wǎng)上下載了十幾張貓和狗的圖片,用于檢驗(yàn)我們訓(xùn)練好的模型。
- 處理我們下載的圖片
- 加載模型
- 將圖片輸入模型進(jìn)行檢驗(yàn)
代碼如下:
#coding=utf-8 import tensorflow as tf from PIL import Image import matplotlib.pyplot as plt import input_data import numpy as np import model import os #從指定目錄中選取一張圖片 def get_one_image(train): files = os.listdir(train) n = len(files) ind = np.random.randint(0,n) img_dir = os.path.join(train,files[ind]) image = Image.open(img_dir) plt.imshow(image) plt.show() image = image.resize([208, 208]) image = np.array(image) return image def evaluate_one_image(): #存放的是我從百度下載的貓狗圖片路徑 train = '/Users/yangyibo/GitWork/pythonLean/AI/貓狗識(shí)別/testImg/' image_array = get_one_image(train) with tf.Graph().as_default(): BATCH_SIZE = 1 # 因?yàn)橹蛔x取一副圖片 所以batch 設(shè)置為1 N_CLASSES = 2 # 2個(gè)輸出神經(jīng)元,[1,0] 或者 [0,1]貓和狗的概率 # 轉(zhuǎn)化圖片格式 image = tf.cast(image_array, tf.float32) # 圖片標(biāo)準(zhǔn)化 image = tf.image.per_image_standardization(image) # 圖片原來(lái)是三維的 [208, 208, 3] 重新定義圖片形狀 改為一個(gè)4D 四維的 tensor image = tf.reshape(image, [1, 208, 208, 3]) logit = model.inference(image, BATCH_SIZE, N_CLASSES) # 因?yàn)?inference 的返回沒有用激活函數(shù),所以在這里對(duì)結(jié)果用softmax 激活 logit = tf.nn.softmax(logit) # 用最原始的輸入數(shù)據(jù)的方式向模型輸入數(shù)據(jù) placeholder x = tf.placeholder(tf.float32, shape=[208, 208, 3]) # 我門存放模型的路徑 logs_train_dir = '/Users/yangyibo/GitWork/pythonLean/AI/貓狗識(shí)別/saveNet/' # 定義saver saver = tf.train.Saver() with tf.Session() as sess: print("從指定的路徑中加載模型。。。。") # 將模型加載到sess 中 ckpt = tf.train.get_checkpoint_state(logs_train_dir) if ckpt and ckpt.model_checkpoint_path: global_step = ckpt.model_checkpoint_path.split('/')[-1].split('-')[-1] saver.restore(sess, ckpt.model_checkpoint_path) print('模型加載成功, 訓(xùn)練的步數(shù)為 %s' % global_step) else: print('模型加載失敗,,,文件沒有找到') # 將圖片輸入到模型計(jì)算 prediction = sess.run(logit, feed_dict={x: image_array}) # 獲取輸出結(jié)果中最大概率的索引 max_index = np.argmax(prediction) if max_index==0: print('貓的概率 %.6f' %prediction[:, 0]) else: print('狗的概率 %.6f' %prediction[:, 1]) # 測(cè)試 evaluate_one_image()
/Users/yangyibo/GitWork/pythonLean/AI/貓狗識(shí)別/testImg/ 存放的是我從百度下載的貓狗圖片
執(zhí)行結(jié)果:
因?yàn)閺膖estimg 中選取圖片是隨機(jī)的,所以每次執(zhí)行的結(jié)果不同
從指定的路徑中加載模型。。。。
模型加載成功, 訓(xùn)練的步數(shù)為 11999
狗的概率 0.964047
[Finished in 6.8s]
代碼地址:https://github.com/527515025/My-TensorFlow-tutorials/blob/master/貓狗識(shí)別/evaluateCatOrDog.py
歡迎star。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
詳解如何使用Python的Plotly庫(kù)進(jìn)行交互式圖形可視化
Python中有許多強(qiáng)大的工具和庫(kù)可用于創(chuàng)建交互式圖形,其中之一就是Plotly庫(kù),Plotly庫(kù)提供了豐富的功能和靈活的接口,使得創(chuàng)建各種類型的交互式圖形變得簡(jiǎn)單而直觀,本文將介紹如何使用Plotly庫(kù)來(lái)創(chuàng)建交互式圖形,需要的朋友可以參考下2024-05-05Python設(shè)計(jì)模式之適配器模式原理與用法詳解
這篇文章主要介紹了Python設(shè)計(jì)模式之適配器模式原理與用法,結(jié)合實(shí)例形式分析了適配器模式的相關(guān)概念、原理及Python實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01Python對(duì)Tornado請(qǐng)求與響應(yīng)的數(shù)據(jù)處理
這篇文章主要介紹了Python對(duì)Tornado請(qǐng)求與響應(yīng)的數(shù)據(jù)處理,需要的朋友可以參考下2020-02-02keras的三種模型實(shí)現(xiàn)與區(qū)別說(shuō)明
這篇文章主要介紹了keras的三種模型實(shí)現(xiàn)與區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-07-07Python實(shí)現(xiàn)猜年齡游戲代碼實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)猜年齡游戲代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03python爬蟲開發(fā)之使用Python爬蟲庫(kù)requests多線程抓取貓眼電影TOP100實(shí)例
這篇文章主要介紹了python爬蟲開發(fā)之使用Python爬蟲庫(kù)requests多線程抓取貓眼電影TOP100實(shí)例,需要的朋友可以參考下2020-03-03詳解Python中Sync與Async執(zhí)行速度快慢對(duì)比
Python新的版本中支持了async/await語(yǔ)法, 很多文章都在說(shuō)這種語(yǔ)法的實(shí)現(xiàn)代碼會(huì)變得很快, 但是這種快是有場(chǎng)景限制的。這篇文章將嘗試簡(jiǎn)單的解釋為何Async的代碼在某些場(chǎng)景比Sync的代碼快2023-03-03