TensorFlow卷積神經(jīng)網(wǎng)絡(luò)之使用訓(xùn)練好的模型識別貓狗圖片
本文是Python通過TensorFlow卷積神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)貓狗識別的姊妹篇,是加載上一篇訓(xùn)練好的模型,進(jìn)行貓狗識別
本文邏輯:
- 我從網(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/貓狗識別/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)
# 圖片原來是三維的 [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ù),所以在這里對結(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/貓狗識別/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])
# 測試
evaluate_one_image()
/Users/yangyibo/GitWork/pythonLean/AI/貓狗識別/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/貓狗識別/evaluateCatOrDog.py
歡迎star。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
Python動態(tài)配置管理Dynaconf的實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了Python動態(tài)配置管理Dynaconf實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
代碼詳解django中數(shù)據(jù)庫設(shè)置
在本篇文章里小編給大家分享了關(guān)于django中數(shù)據(jù)庫設(shè)置的相關(guān)實(shí)例內(nèi)容,有興趣的朋友們跟著學(xué)習(xí)下。2019-01-01
Python機(jī)器學(xué)習(xí)NLP自然語言處理基本操作關(guān)鍵詞
本文是Python機(jī)器學(xué)習(xí)NLP自然語言處理系列文章,帶大家開啟一段學(xué)習(xí)自然語言處理 (NLP) 的旅程. 本文主要學(xué)習(xí)NLP自然語言處理關(guān)鍵詞的操作2021-09-09
Python實(shí)現(xiàn)快速多線程ping的方法
這篇文章主要介紹了Python實(shí)現(xiàn)快速多線程ping的方法,實(shí)例分析了Python多線程及ICMP數(shù)據(jù)包的發(fā)送技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
python計(jì)算書頁碼的統(tǒng)計(jì)數(shù)字問題實(shí)例
這篇文章主要介紹了python計(jì)算書頁碼的統(tǒng)計(jì)數(shù)字問題實(shí)例,對比2個(gè)實(shí)例講述了數(shù)字統(tǒng)計(jì)的技巧,非常實(shí)用,需要的朋友可以參考下2014-09-09
python的import?機(jī)制是怎么實(shí)現(xiàn)的
這篇文章主要介紹了python的import?機(jī)制是怎么實(shí)現(xiàn)的,import有Python運(yùn)行時(shí)的全局模塊池的維護(hù)和搜索、解析與搜索模塊路徑的樹狀結(jié)構(gòu)等作用,下文具體相關(guān)介紹需要的小伙伴可以參考一下2022-05-05
Python smtplib實(shí)現(xiàn)發(fā)送郵件功能
這篇文章主要為大家詳細(xì)介紹了Python smtplib實(shí)現(xiàn)發(fā)送郵件功能,包含文本、附件、圖片等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
python飛機(jī)大戰(zhàn)pygame碰撞檢測實(shí)現(xiàn)方法分析
這篇文章主要介紹了python飛機(jī)大戰(zhàn)pygame碰撞檢測實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Python使用pygame實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲中碰撞檢測的原理與相關(guān)操作技巧,需要的朋友可以參考下2019-12-12

