0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

利用Python實(shí)現(xiàn)網(wǎng)頁(yè)應(yīng)用程序,可圖片識(shí)別狗的類(lèi)型(附源碼)

如意 ? 來(lái)源:OFweek電子工程網(wǎng) ? 作者:磐創(chuàng)AI ? 2020-10-08 14:45 ? 次閱讀

在這篇文章中,將教大家實(shí)現(xiàn)一個(gè)網(wǎng)頁(yè)應(yīng)用程序,該程序可以接收狗的圖片,然后輸出其品種,其準(zhǔn)確率超過(guò)80%!

我們將使用深度學(xué)習(xí)來(lái)訓(xùn)練一個(gè)識(shí)別狗品種的模型,數(shù)據(jù)集是狗圖像與他們的品種信息,通過(guò)學(xué)習(xí)圖像的特征來(lái)區(qū)分狗的品種。數(shù)據(jù)分析數(shù)據(jù)集可以從這里下載(https://s3-us-west-1.a(chǎn)mazonaws.com/udacity-aind/dog-project/dogImages.zip)。以下是關(guān)于數(shù)據(jù)的一些介紹:犬種總數(shù):133狗圖片總數(shù):8351(訓(xùn)練集:6680,驗(yàn)證集:835,測(cè)試集:836)最受歡迎的品種:阿拉斯加對(duì)應(yīng)96個(gè)樣本,博德牧羊犬對(duì)應(yīng)93個(gè)樣本按圖片數(shù)量排序的前30個(gè)品種如下:

利用Python實(shí)現(xiàn)網(wǎng)頁(yè)應(yīng)用程序,可圖片識(shí)別狗的類(lèi)型(附源碼)

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

數(shù)據(jù)預(yù)處理我們會(huì)把每個(gè)圖像作為一個(gè)numpy數(shù)組進(jìn)行加載,并將它們的大小調(diào)整為224x224,這是大多數(shù)傳統(tǒng)神經(jīng)網(wǎng)絡(luò)接受圖像的默認(rèn)大小,另外我們?yōu)閳D像的數(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ù)集上從頭開(kāi)始訓(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ù)較高的模型。通過(guò)測(cè)試模型,我們得到的準(zhǔn)確率只有1%左右使用遷移學(xué)習(xí)現(xiàn)在,我們使用遷移學(xué)習(xí)來(lái)實(shí)現(xiàn)更高的準(zhǔn)確率。首先我們下載ResNet-50,可以通過(guò)運(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)沒(méi)有增加,我們使用額外的回調(diào)來(lái)降低學(xué)習(xí)率;如果驗(yàn)證損失在連續(xù)的5個(gè)epoch內(nèi)沒(méi)有增加,可以提前停止訓(xùn)練。Resnet50_model = tf.keras.models.Sequential()Resnet50_model.a(chǎn)dd(tf.keras.layers.GlobalAveragePooling2D(input_shape=train_Resnet50.shape[1:]))Resnet50_model.a(chǎn)dd(tf.keras.layers.Dense(1024, activation='relu'))Resnet50_model.a(chǎn)dd(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)用程序?qū)τ趙eb應(yīng)用程序,我們首先編寫(xiě)了一個(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.a(chǎn)rgmax(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是分別顯示圖像及其犬種的模板。

結(jié)論

祝賀你!你已經(jīng)成功地實(shí)現(xiàn)了一個(gè)狗品種分類(lèi)器,并且可以準(zhǔn)確地分辨出狗的品種。讓我們總結(jié)一下我們?cè)谶@里學(xué)到的知識(shí):我們對(duì)數(shù)據(jù)集進(jìn)行了分析和預(yù)處理。機(jī)器學(xué)習(xí)算法需要單獨(dú)的訓(xùn)練集、測(cè)試集和驗(yàn)證集來(lái)進(jìn)行置信預(yù)測(cè)。我們從零開(kāi)始使用CNN,由于未能提取特征,所以表現(xiàn)不佳。然后我們使用了遷移學(xué)習(xí),準(zhǔn)確度大大提高最后,我們構(gòu)建了一個(gè)Flask web應(yīng)用程序來(lái)實(shí)現(xiàn)我們的項(xiàng)目封裝我們確實(shí)學(xué)到了很多東西,但你還可以嘗試很多其他的事情。你可以在heroku上部署web應(yīng)用程序,也可以嘗試使用不同的層(如Dropout層)來(lái)提高準(zhǔn)確性。

參考鏈接:https://towardsdatascience.com/dont-know-the-breed-of-your-dog-ml-can-h(huán)elp-6558eb5f7f05
責(zé)編AJX

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4551

    瀏覽量

    92012
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    37

    文章

    3198

    瀏覽量

    57356
  • python
    +關(guān)注

    關(guān)注

    53

    文章

    4752

    瀏覽量

    84065
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    用C#編寫(xiě)一個(gè)抓網(wǎng)頁(yè)應(yīng)用程序

    用C#編寫(xiě)一個(gè)抓網(wǎng)頁(yè)應(yīng)用程序本文利用C#和.NET提供的類(lèi)來(lái)輕松創(chuàng)建一個(gè)抓取網(wǎng)頁(yè)內(nèi)容源代碼的程序 。HTTP是WWW進(jìn)行數(shù)據(jù)訪(fǎng)問(wèn)最基本的協(xié)
    發(fā)表于 12-26 12:25

    python實(shí)現(xiàn)網(wǎng)頁(yè)爬蟲(chóng)爬取圖片

    打開(kāi)一個(gè)URL地址;read()方法用于讀取URL上的數(shù)據(jù);向getHtml()函數(shù)傳遞一個(gè)網(wǎng)址,并把整個(gè)頁(yè)面下載下來(lái)。執(zhí)行程序就會(huì)把整個(gè)網(wǎng)頁(yè)打印輸出。二. 篩選頁(yè)面中想要的數(shù)據(jù) Python 提供了
    發(fā)表于 04-05 15:32

    在線(xiàn)客服源碼C++、ASP、PHP等的比較

    ASP、PHP、JSP類(lèi)在線(xiàn)客服源碼都是基于網(wǎng)頁(yè)源碼,雖然它們基本也有一個(gè)應(yīng)用程序外觀,但是都是在軟件窗口內(nèi)嵌的網(wǎng)頁(yè),從技術(shù)角度來(lái)說(shuō),其本
    發(fā)表于 04-13 21:05 ?44次下載

    利用FTP實(shí)現(xiàn)應(yīng)用程序的遠(yuǎn)程更新

    FTP (File Transfer Protocol),是用于Internet上的控制文件的雙向傳輸?shù)膮f(xié)議。同時(shí),它也是一個(gè)應(yīng)用程序。本方案主要介紹如何利用網(wǎng)絡(luò)(以太網(wǎng)、GPRS上網(wǎng)),通過(guò)FTP協(xié)議來(lái)實(shí)現(xiàn)
    發(fā)表于 06-09 16:08 ?46次下載

    奧迪quattro coaster AR應(yīng)用程序識(shí)別”具體的奧迪電視廣告

    奧迪quattro coaster AR應(yīng)用程序識(shí)別”具體的奧迪電視廣告,是廣告民眾參與式擴(kuò)展體驗(yàn)! 奧迪發(fā)布了一款由他們的電視廣告觸發(fā)的,新的AR智能手機(jī)
    發(fā)表于 02-08 07:43 ?1656次閱讀

    STM32和TFT彩屏顯示圖片程序取模軟件)免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是STM32和TFT彩屏顯示圖片程序取模軟件)免費(fèi)下載。
    發(fā)表于 09-19 17:21 ?174次下載
    STM32和TFT彩屏顯示<b class='flag-5'>圖片</b><b class='flag-5'>程序</b>(<b class='flag-5'>附</b>取模軟件)免費(fèi)下載

    python3.3抓取網(wǎng)頁(yè)數(shù)據(jù)的程序資料免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是python3.3抓取網(wǎng)頁(yè)數(shù)據(jù)的程序資料免費(fèi)下載。
    發(fā)表于 01-29 15:19 ?21次下載
    <b class='flag-5'>python</b>3.3抓取<b class='flag-5'>網(wǎng)頁(yè)</b>數(shù)據(jù)的<b class='flag-5'>程序</b>資料免費(fèi)下載

    如何利用Python和函數(shù)庫(kù)進(jìn)行簡(jiǎn)單的人臉識(shí)別?(源碼

    本文將介紹圖像處理中的一些重要概念,除了具體解釋每個(gè)步驟之外,還將提供一個(gè)在Python中使用Cv2和DLib庫(kù)輕松進(jìn)行人臉識(shí)別的項(xiàng)目。
    的頭像 發(fā)表于 09-04 14:06 ?3067次閱讀
    如何<b class='flag-5'>利用</b><b class='flag-5'>Python</b>和函數(shù)庫(kù)進(jìn)行簡(jiǎn)單的人臉<b class='flag-5'>識(shí)別</b>?(<b class='flag-5'>附</b><b class='flag-5'>源碼</b>)

    使用Python實(shí)現(xiàn)車(chē)牌識(shí)別程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是使用Python實(shí)現(xiàn)車(chē)牌識(shí)別程序免費(fèi)下載。
    發(fā)表于 09-11 16:12 ?35次下載
    使用<b class='flag-5'>Python</b><b class='flag-5'>實(shí)現(xiàn)</b>車(chē)牌<b class='flag-5'>識(shí)別</b>的<b class='flag-5'>程序</b>免費(fèi)下載

    不同應(yīng)用程序的存儲(chǔ)IO類(lèi)型解析

    的數(shù)據(jù)訪(fǎng)問(wèn)類(lèi)型有所不同。 本文描述典型的不同應(yīng)用程序的存儲(chǔ)IO類(lèi)型。幫助讀者了解不同應(yīng)用程序存儲(chǔ)IO類(lèi)型的同時(shí),提供的數(shù)據(jù)也可以為存儲(chǔ)模擬和
    的頭像 發(fā)表于 11-30 15:21 ?2135次閱讀
    不同<b class='flag-5'>應(yīng)用程序</b>的存儲(chǔ)IO<b class='flag-5'>類(lèi)型</b>解析

    python v3.8.0應(yīng)用程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是python v3.8.0應(yīng)用程序免費(fèi)下載。
    發(fā)表于 12-29 08:00 ?0次下載
    <b class='flag-5'>python</b> v3.8.0<b class='flag-5'>應(yīng)用程序</b>免費(fèi)下載

    電機(jī)正反轉(zhuǎn)互鎖控制應(yīng)用程序源碼下載

    電機(jī)正反轉(zhuǎn)互鎖控制應(yīng)用程序源碼下載
    發(fā)表于 04-06 17:23 ?42次下載
    電機(jī)正反轉(zhuǎn)互鎖控制<b class='flag-5'>應(yīng)用程序</b><b class='flag-5'>源碼</b>下載

    蜂鳴器播放音樂(lè)設(shè)計(jì)與實(shí)現(xiàn)源碼

    蜂鳴器播放音樂(lè)設(shè)計(jì)與實(shí)現(xiàn)源碼
    發(fā)表于 04-24 11:00 ?87次下載
    蜂鳴器播放音樂(lè)設(shè)計(jì)與<b class='flag-5'>實(shí)現(xiàn)</b>(<b class='flag-5'>附</b><b class='flag-5'>源碼</b>)

    基于51單片機(jī)的圖書(shū)管理系統(tǒng)實(shí)現(xiàn)與設(shè)計(jì)(源碼)

    基于51單片機(jī)的圖書(shū)管理系統(tǒng)實(shí)現(xiàn)與設(shè)計(jì)(源碼)
    發(fā)表于 04-26 10:52 ?18次下載

    什么是網(wǎng)頁(yè)應(yīng)用程序測(cè)試?

    網(wǎng)頁(yè)app測(cè)試,或網(wǎng)頁(yè)測(cè)試,是一種軟件測(cè)試實(shí)踐,有助于根據(jù)要求確保應(yīng)用程序的質(zhì)量和功能。網(wǎng)頁(yè)測(cè)試必須在交付之前檢測(cè)所有潛在問(wèn)題,例如功能差異、安全漏洞、集成問(wèn)題、網(wǎng)絡(luò)環(huán)境問(wèn)題或流量壓力
    的頭像 發(fā)表于 05-11 14:09 ?718次閱讀