内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

怎么使用keras識(shí)別狗的品種

這篇文章主要介紹“怎么使用keras識(shí)別狗的品種”,在日常操作中,相信很多人在怎么使用keras識(shí)別狗的品種問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”怎么使用keras識(shí)別狗的品種”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

創(chuàng)新互聯(lián)是一家專業(yè)提供海城企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站制作、成都做網(wǎng)站、html5、小程序制作等業(yè)務(wù)。10年已為海城眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

數(shù)據(jù)分析

以下是關(guān)于數(shù)據(jù)的一些介紹:

  1. 犬種總數(shù):133

  2. 狗圖片總數(shù):8351(訓(xùn)練集:6680,驗(yàn)證集:835,測(cè)試集:836)

  3. 最受歡迎的品種:阿拉斯加:96,博德牧羊犬:93

按圖片數(shù)量排序的前30個(gè)品種如下:

怎么使用keras識(shí)別狗的品種

我們還可以在這里看到一些狗的圖片和它們的品種:

怎么使用keras識(shí)別狗的品種


數(shù)據(jù)預(yù)處理

經(jīng)過分析,為機(jī)器學(xué)習(xí)算法準(zhǔn)備數(shù)據(jù)。我們將把每個(gè)圖像作為一個(gè)numpy數(shù)組加載,并將它們的大小調(diào)整為224x224,因?yàn)檫@是大多數(shù)傳統(tǒng)神經(jīng)網(wǎng)絡(luò)接受圖像的默認(rèn)大小。我們還將為圖像的數(shù)量添加另一個(gè)維度

from keras.preprocessing import image                  
from tqdm import tqdm

def path_to_tensor(img_path):
    '''將給定路徑下的圖像轉(zhuǎn)換為張量'''
    img = image.load_img(img_path, target_size=(224, 224))
    x = image.img_to_array(img)
    return np.expand_dims(x, axis=0)

def paths_to_tensor(img_paths):
    '''將給定路徑中的所有圖像轉(zhuǎn)換為張量'''
    list_of_tensors = [path_to_tensor(img_path) for img_path in tqdm(img_paths)]
    return np.vstack(list_of_tensors)

最后,我們將使用ImageDataGenerator對(duì)圖像進(jìn)行動(dòng)態(tài)縮放和增強(qiáng)

train_datagen = tf.keras.preprocessing.image.ImageDataGenerator(rescale=1./255,
                                                horizontal_flip=True,
                                                vertical_flip=True,
                                                rotation_range=20)

valid_datagen = tf.keras.preprocessing.image.ImageDataGenerator(rescale=1./255.)

test_datagen = tf.keras.preprocessing.image.ImageDataGenerator(rescale=1./255.)


train_generator = train_datagen.flow(train_tensors, train_targets, batch_size=32)
valid_generator = train_datagen.flow(valid_tensors, valid_targets, batch_size=32)
test_generator = train_datagen.flow(test_tensors, test_targets, batch_size=32)

CNN

我們將在預(yù)處理數(shù)據(jù)集上從頭開始訓(xùn)練卷積神經(jīng)網(wǎng)絡(luò)(CNN),如下所示:

model = tf.keras.models.Sequential([
    tf.keras.layers.Conv2D(16, (3,3), activation='relu', input_shape=(224, 224, 3)),
    tf.keras.layers.MaxPooling2D(2, 2),
    tf.keras.layers.Conv2D(32, (3,3), activation='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    tf.keras.layers.Conv2D(64, (3,3), activation='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    tf.keras.layers.Conv2D(128, (3,3), activation='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    tf.keras.layers.Conv2D(256, (3,3), activation='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    tf.keras.layers.Flatten(),
    tf.keras.layers.Dense(2048, activation='softmax'),
    tf.keras.layers.Dropout(0.5),
    tf.keras.layers.Dense(1024, activation='softmax'),
    tf.keras.layers.Dropout(0.5),
    tf.keras.layers.Dense(133, activation='softmax')
])


model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy'])

checkpointer = tf.keras.callbacks.ModelCheckpoint(filepath='../saved_models/weights_best_custom.hdf5', 
                               verbose=1, save_best_only=True)

model.fit(train_generator, epochs=5, validation_data=valid_generator, callbacks=[checkpointer])

我們使用一個(gè)ModelCheckpoint回調(diào)來(lái)保存基于驗(yàn)證分?jǐn)?shù)的模型。測(cè)試這個(gè)模型,我們得到的準(zhǔn)確率只有1%左右


使用遷移學(xué)習(xí)

現(xiàn)在,我們將看到如何使用預(yù)訓(xùn)練的特征可以產(chǎn)生巨大的不同。下載ResNet-50。你可以通過運(yùn)行下面的代碼單元來(lái)提取相應(yīng)的訓(xùn)練集、測(cè)試和驗(yàn)證集:

bottleneck_features = np.load('Data/bottleneck_features/DogResnet50Data.npz')
train_Resnet50 = bottleneck_features['train']
valid_Resnet50 = bottleneck_features['valid']
test_Resnet50 = bottleneck_features['test']

我們現(xiàn)在將再次定義模型,并對(duì)提取的特征使用GlobalAveragePooling2D,它將一組特征平均為一個(gè)值。最后,如果驗(yàn)證損失在兩個(gè)連續(xù)的epoch內(nèi)沒有增加,我們使用額外的回調(diào)來(lái)降低學(xué)習(xí)率,降低平臺(tái),并且如果驗(yàn)證損失在連續(xù)的5個(gè)epoch內(nèi)沒有增加,也可以提前停止訓(xùn)練。

Resnet50_model = tf.keras.models.Sequential()
Resnet50_model.add(tf.keras.layers.GlobalAveragePooling2D(input_shape=train_Resnet50.shape[1:]))
Resnet50_model.add(tf.keras.layers.Dense(1024, activation='relu'))
Resnet50_model.add(tf.keras.layers.Dense(133, activation='softmax'))

Resnet50_model.compile(loss='categorical_crossentropy', optimizer='rmsprop', metrics=['accuracy'])

checkpointer = tf.keras.callbacks.ModelCheckpoint(filepath='saved_models/weights_best_Resnet50.hdf5', 
                               verbose=1, save_best_only=True)
early_stopping = tf.keras.callbacks.EarlyStopping(patience=5, monitor='val_loss')

reduce_lr = tf.keras.callbacks.ReduceLROnPlateau(patience=2, monitor='val_loss')
Resnet50_model.fit(train_Resnet50, train_targets, 
          validation_data=(valid_Resnet50, valid_targets),
          epochs=50, batch_size=20, callbacks=[checkpointer, early_stopping, reduce_lr], verbose=1)### 訓(xùn)練模型

在測(cè)試集上的準(zhǔn)確率為82.65%。與我們白手起家訓(xùn)練的模型相比,這是一個(gè)巨大的進(jìn)步。


構(gòu)建web應(yīng)用程序

對(duì)于web應(yīng)用程序,我們將首先編寫一個(gè)helper函數(shù),該函數(shù)接受圖像路徑并返回品種。label_to_cat字典將每個(gè)數(shù)字標(biāo)簽映射到它的狗品種。

def predict_breed(img_path):
    '''預(yù)測(cè)給定圖像的品種'''
    # 提取特征
    bottleneck_feature = extract_Resnet50(path_to_tensor(img_path))
    bottleneck_feature = tf.keras.models.Sequential([
                            tf.keras.layers.GlobalAveragePooling2D(input_shape=bottleneck_feature.shape[1:])
                        ]).predict(bottleneck_feature).reshape(1, 1, 1, 2048)
    # 獲得預(yù)測(cè)向量
    predicted_vector = Resnet50_model.predict(bottleneck_feature)
    # 模型預(yù)測(cè)的犬種
    return label_to_cat[np.argmax(predicted_vector)]

對(duì)于web應(yīng)用程序,我們將使用flaskweb框架來(lái)幫助我們用最少的代碼創(chuàng)建web應(yīng)用程序。我們將定義一個(gè)接受圖像的路由,并用狗的品種呈現(xiàn)一個(gè)輸出模板

@app.route('/upload', methods=['POST','GET'])
def upload_file():
    if request.method == 'GET':
        return render_template('index.html')
    else:
        file = request.files['image']
        full_name = os.path.join(UPLOAD_FOLDER, file.filename)
        file.save(full_name)
        dog_breed = dog_breed_classifier(full_name)
    return render_template('predict.html', image_file_name = file.filename, label = dog_breed)

predict.html是分別顯示圖像及其犬種的模板。

到此,關(guān)于“怎么使用keras識(shí)別狗的品種”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

網(wǎng)頁(yè)題目:怎么使用keras識(shí)別狗的品種
本文URL:http://m.rwnh.cn/article30/jcjdso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、外貿(mào)網(wǎng)站建設(shè)、企業(yè)建站網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站營(yíng)銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
溆浦县| 田林县| 昌宁县| 九龙县| 阿瓦提县| 营山县| 绍兴县| 西贡区| 井研县| 东光县| 库车县| 赤水市| 平泉县| 隆昌县| 吕梁市| 邢台县| 巩留县| 沁阳市| 刚察县| 英超| 高安市| 苏尼特右旗| 乡城县| 徐水县| 托克逊县| 仪征市| 牡丹江市| 萨嘎县| 瓮安县| 天峨县| 阿荣旗| 湄潭县| 香格里拉县| 林周县| 香格里拉县| 泗阳县| 女性| 岳西县| 涡阳县| 耿马| 迁安市|