keras-vgg16識(shí)別貓狗


一、實(shí)現(xiàn)軟件配置

1.keras2.2.0-tensorflow-GPU1.8

2.python3.6

3.spyder3.3.2

二、實(shí)現(xiàn)步驟

1.收集貓狗數(shù)據(jù)集按照? ?image/train/cat 和image/train/cat 文件夾的形式保存 test相同方法

2.下載載入預(yù)訓(xùn)練的VGG16模型,不包括全連接層

3.載入預(yù)訓(xùn)練的模型vgg16? ?重新搭建全連接層 將預(yù)訓(xùn)練模型與全連接層合并

4.使用ImageDataGenerator 和train_datagen.flow_from_directory函數(shù)對(duì)數(shù)據(jù)集進(jìn)行處理

5.使用model.compile定義優(yōu)化器和損失函數(shù)??

6.使用model.fit_generator定義訓(xùn)練參數(shù)

7.使用model.save('model_vgg16.h5')保存模型

8.畫圖

三、實(shí)現(xiàn)代碼

# -*- coding: utf-8 -*-

"""

Created on Wed Feb 26 11:47:42 2020

@author: Administrator

"""

from keras.applications.vgg16 import VGG16

from keras.preprocessing import image

from keras.applications.vgg16 import preprocess_input

import numpy as np

from keras.preprocessing.image import ImageDataGenerator

from keras.models import Sequential

from keras.layers import Dropout, Flatten, Dense

from keras.optimizers import SGD

import matplotlib.pyplot as plt



# 載入預(yù)訓(xùn)練的VGG16模型碗旅,不包括全連接層

vgg16_model = VGG16(weights='imagenet', include_top=False, input_shape=(150,150,3))


# 搭建全連接層

top_model = Sequential()

top_model.add(Flatten(input_shape=vgg16_model.output_shape[1:]))

top_model.add(Dense(256, activation='relu'))

top_model.add(Dropout(0.5))

top_model.add(Dense(2, activation='softmax'))

model = Sequential()? ? ? ? ? ? ? #將vgg16與自定義全連接層合并

model.add(vgg16_model)

model.add(top_model)

#訓(xùn)練數(shù)據(jù)集 處理

train_datagen = ImageDataGenerator(

#? ? ? ? rotation_range = 40,? ? ? # 隨機(jī)旋轉(zhuǎn)角度

#? ? ? ? width_shift_range = 0.2,? # 隨機(jī)水平平移

#? ? ? ? height_shift_range = 0.2, # 隨機(jī)豎直平移

? ? ? ? rescale = 1./255,? ? ? ? # 數(shù)值歸一化

? ? ? ? shear_range = 0.2,? ? ? ? # 隨機(jī)裁剪

? ? ? ? zoom_range? =0.2,? ? ? ? # 隨機(jī)放大

? ? ? ? horizontal_flip = True,? # 水平翻轉(zhuǎn)

? ? ? ? fill_mode='nearest')? ? ? # 填充方式

#測(cè)試集處理

test_datagen = ImageDataGenerator(

? ? ? ? rescale = 1./255? ? ? ? ? #數(shù)據(jù)歸一化

? ? ? ? )

batch_size = 32

#生成訓(xùn)練數(shù)據(jù)

train_generator = train_datagen.flow_from_directory(

? ? ? ? 'image/train',

#? ? ? ? target_size = (150,150),

? ? ? ? target_size = (200,200),

? ? ? ? batch_size = batch_size,

? ? ? ? )

#生成測(cè)試數(shù)據(jù)

test_generator = test_datagen.flow_from_directory(

? ? ? ? 'image/test',

#? ? ? ? target_size = (150,150),

? ? ? ? target_size = (200,200),

? ? ? ? batch_size = batch_size,

? ? ? ? )

#train_generator.class_indices

#定義優(yōu)化器 代價(jià)函數(shù) 訓(xùn)練過程中計(jì)算準(zhǔn)確率

model.compile(optimizer=SGD(lr=1e-4,momentum=0.9),loss='categorical_crossentropy',metrics=['accuracy'])

history = model.fit_generator(train_generator,steps_per_epoch=10,

? ? ? ? ? ? ? ? ? ? epochs=20,

? ? ? ? ? ? ? ? ? ? validation_data = test_generator,? ? ? ? ? ? ? ? ? #? validation_data為驗(yàn)證數(shù)據(jù)集

? ? ? ? ? ? ? ? ? ? validation_steps = len(test_generator)

? ? ? ? ? ? ? ? ? ? )

#保存模型和參數(shù)? ?

#只保存模型參數(shù)用model.save_weight('路徑')? 載入模型參數(shù) 先導(dǎo)入load_weights模塊 在使用model.load_weights(路徑)

#保存網(wǎng)絡(luò)結(jié)構(gòu)的話from tensorflow.keras.model imort model_from_json? json_string = model.to_json()? 載入網(wǎng)絡(luò)結(jié)構(gòu)? model = model_from_json(json_string)

model.save('model_vgg16.h5')

#畫出模型圖

acc = history.history['acc']? ? ? ? ? ? #獲取訓(xùn)練集準(zhǔn)確性數(shù)據(jù)

val_acc = history.history['val_acc']? ? #獲取驗(yàn)證集準(zhǔn)確性數(shù)據(jù)

loss = history.history['loss']? ? ? ? ? #獲取訓(xùn)練集錯(cuò)誤值數(shù)據(jù)

val_loss = history.history['val_loss']? #獲取驗(yàn)證集錯(cuò)誤值數(shù)據(jù)

epochs = range(1,len(acc)+1)

plt.title('model accuracy')? ? ? ? ? ? #標(biāo)題

plt.ylabel('accuracy')? ? ? ? ? ? ? ? ? #y軸名稱

plt.xlabel('epoch')? ? ? ? ? ? ? ? ? ? #x軸名稱

plt.plot(epochs,acc,label='Train_acc')? ? #以epochs為橫坐標(biāo),以訓(xùn)練集準(zhǔn)確性為縱坐標(biāo)

plt.plot(epochs,val_acc,label='Val_acc') #以epochs為橫坐標(biāo),以驗(yàn)證集準(zhǔn)確性為縱坐標(biāo)

plt.plot(epochs,loss,label='Train_loss')

plt.plot(epochs,val_loss,label='Val_loss')

plt.legend(loc='upper left')? #繪制圖例辰企,即標(biāo)明圖中的線段代表何種含義

plt.savefig('loss-acc.png')

plt.show()? ? #顯示所有圖表

四、訓(xùn)練結(jié)果


五蚯斯、測(cè)試代碼

from keras.models import load_model,Sequential

import numpy as np

from keras.preprocessing.image import load_img,img_to_array

label = np.array(['cat','dog'])

#載入模型

model = load_model('model_vgg16.h5')

#導(dǎo)入圖片

path = 'temp/2.jpg'

image = load_img(path)

image = image.resize((150,150))

image = img_to_array(image)

image = image/255

image = np.expand_dims(image,0)

image.shape

#print(label[model.predict_class(image)])

predict = model.predict(image)? ? ? ? ? ? ? #采用合并預(yù)測(cè)的方法

predict=np.argmax(predict,axis=1)

print(label[predict])

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末薄风,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子拍嵌,更是在濱河造成了極大的恐慌遭赂,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件横辆,死亡現(xiàn)場(chǎng)離奇詭異撇他,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)狈蚤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門困肩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人脆侮,你說我怎么就攤上這事锌畸。” “怎么了靖避?”我有些...
    開封第一講書人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵潭枣,是天一觀的道長比默。 經(jīng)常有香客問我,道長盆犁,這世上最難降的妖魔是什么命咐? 我笑而不...
    開封第一講書人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮谐岁,結(jié)果婚禮上醋奠,老公的妹妹穿的比我還像新娘。我一直安慰自己翰铡,他們只是感情好钝域,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著锭魔,像睡著了一般例证。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上迷捧,一...
    開封第一講書人閱讀 49,985評(píng)論 1 291
  • 那天织咧,我揣著相機(jī)與錄音,去河邊找鬼漠秋。 笑死笙蒙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的庆锦。 我是一名探鬼主播捅位,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼搂抒!你這毒婦竟也來了艇搀?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤求晶,失蹤者是張志新(化名)和其女友劉穎焰雕,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芳杏,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡矩屁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了爵赵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吝秕。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖空幻,靈堂內(nèi)的尸體忽然破棺而出郭膛,到底是詐尸還是另有隱情,我是刑警寧澤氛悬,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布则剃,位于F島的核電站耘柱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏棍现。R本人自食惡果不足惜调煎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望己肮。 院中可真熱鬧士袄,春花似錦、人聲如沸谎僻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽艘绍。三九已至赤拒,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诱鞠,已是汗流浹背挎挖。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留航夺,地道東北人蕉朵。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像阳掐,于是被迫代替她去往敵國和親始衅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容