国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù)

這篇具有很好參考價值的文章主要介紹了競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

1 前言

Hi,大家好,這里是丹成學(xué)長,今天做一個 基于深度學(xué)習(xí)的水果識別demo

這是一個較為新穎的競賽課題方向,學(xué)長非常推薦!

?? 更多資料, 項目分享:

https://gitee.com/dancheng-senior/postgraduate文章來源地址http://www.zghlxwxcb.cn/news/detail-787409.html

2 開發(fā)簡介

深度學(xué)習(xí)作為機器學(xué)習(xí)領(lǐng)域內(nèi)新興并且蓬勃發(fā)展的一門學(xué)科, 它不僅改變著傳統(tǒng)的機器學(xué)習(xí)方法, 也影響著我們對人類感知的理解,
已經(jīng)在圖像識別和語音識別等領(lǐng)域取得廣泛的應(yīng)用。 因此, 本文在深入研究深度學(xué)習(xí)理論的基礎(chǔ)上, 將深度學(xué)習(xí)應(yīng)用到水果圖像識別中,
以此來提高了水果圖像的識別性能。

3 識別原理

3.1 傳統(tǒng)圖像識別原理

傳統(tǒng)的水果圖像識別系統(tǒng)的一般過程如下圖所示,主要工作集中在圖像預(yù)處理和特征提取階段。

在大多數(shù)的識別任務(wù)中, 實驗所用圖像往往是在嚴格限定的環(huán)境中采集的, 消除了外界環(huán)境對圖像的影響。 但是實際環(huán)境中圖像易受到光照變化、 水果反光、
遮擋等因素的影響, 這在不同程度上影響著水果圖像的識別準確率。

在傳統(tǒng)的水果圖像識別系統(tǒng)中, 通常是對水果的紋理、 顏色、 形狀等特征進行提取和識別。

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

3.2 深度學(xué)習(xí)水果識別

CNN 是一種專門為識別二維特征而設(shè)計的多層神經(jīng)網(wǎng)絡(luò), 它的結(jié)構(gòu)如下圖所示,這種結(jié)構(gòu)對平移、 縮放、 旋轉(zhuǎn)等變形具有高度的不變性。

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

學(xué)長本次采用的 CNN 架構(gòu)如圖:
競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

4 數(shù)據(jù)集

  • 數(shù)據(jù)庫分為訓(xùn)練集(train)和測試集(test)兩部分

  • 訓(xùn)練集包含四類apple,orange,banana,mixed(多種水果混合)四類237張圖片;測試集包含每類圖片各兩張。圖片集如下圖所示。

  • 圖片類別可由圖片名稱中提取。

訓(xùn)練集圖片預(yù)覽

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

測試集預(yù)覽
競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

數(shù)據(jù)集目錄結(jié)構(gòu)
競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

5 部分關(guān)鍵代碼

5.1 處理訓(xùn)練集的數(shù)據(jù)結(jié)構(gòu)

import os
import pandas as pd    

train_dir = './Training/'
test_dir = './Test/'
fruits = []
fruits_image = []

for i in os.listdir(train_dir):
    for image_filename in os.listdir(train_dir + i):
        fruits.append(i) # name of the fruit
        fruits_image.append(i + '/' + image_filename)
train_fruits = pd.DataFrame(fruits, columns=["Fruits"])
train_fruits["Fruits Image"] = fruits_image

print(train_fruits)

5.2 模型網(wǎng)絡(luò)結(jié)構(gòu)

    
?    import matplotlib.pyplot as plt
?    import seaborn as sns
?    from keras.preprocessing.image import ImageDataGenerator, img_to_array, load_img
?    from glob import glob
?    from keras.models import Sequential
?    from keras.layers import Conv2D, MaxPooling2D, Activation, Dropout, Flatten, Dense
?    img = load_img(train_dir + "Cantaloupe 1/r_234_100.jpg")
?    plt.imshow(img)
?    plt.axis("off")
?    plt.show()
?    

    array_image = img_to_array(img)
    
    # shape (100,100)
    print("Image Shape --> ", array_image.shape)
    
    # 131個類目
    fruitCountUnique = glob(train_dir + '/*' )
    numberOfClass = len(fruitCountUnique)
    print("How many different fruits are there --> ",numberOfClass)
    
    # 構(gòu)建模型
    model = Sequential()
    model.add(Conv2D(32,(3,3),input_shape = array_image.shape))
    model.add(Activation("relu"))
    model.add(MaxPooling2D())
    model.add(Conv2D(32,(3,3)))
    model.add(Activation("relu"))
    model.add(MaxPooling2D())
    model.add(Conv2D(64,(3,3)))
    model.add(Activation("relu"))
    model.add(MaxPooling2D())
    model.add(Flatten())
    model.add(Dense(1024))
    model.add(Activation("relu"))
    model.add(Dropout(0.5))
    
    # 區(qū)分131類
    model.add(Dense(numberOfClass)) # output
    model.add(Activation("softmax"))
    model.compile(loss = "categorical_crossentropy",
    
                  optimizer = "rmsprop",
    
                  metrics = ["accuracy"])
    
    print("Target Size --> ", array_image.shape[:2])


## 

5.3 訓(xùn)練模型

    
?    train_datagen = ImageDataGenerator(rescale= 1./255,
?                                       shear_range = 0.3,
?                                       horizontal_flip=True,
?                                       zoom_range = 0.3)
?    

    test_datagen = ImageDataGenerator(rescale= 1./255)
    epochs = 100
    batch_size = 32
    train_generator = train_datagen.flow_from_directory(
                    train_dir,
                    target_size= array_image.shape[:2],
                    batch_size = batch_size,
                    color_mode= "rgb",
                    class_mode= "categorical")
    
    test_generator = test_datagen.flow_from_directory(
                    test_dir,
                    target_size= array_image.shape[:2],
                    batch_size = batch_size,
                    color_mode= "rgb",
                    class_mode= "categorical")
    
    for data_batch, labels_batch in train_generator:
        print("data_batch shape --> ",data_batch.shape)
        print("labels_batch shape --> ",labels_batch.shape)
        break
    
    hist = model.fit_generator(
            generator = train_generator,
            steps_per_epoch = 1600 // batch_size,
            epochs=epochs,
            validation_data = test_generator,
            validation_steps = 800 // batch_size)
    
    #保存模型 model_fruits.h5
    model.save('model_fruits.h5')


順便輸出訓(xùn)練曲線

?

    #展示損失模型結(jié)果
?    plt.figure()
?    plt.plot(hist.history["loss"],label = "Train Loss", color = "black")
?    plt.plot(hist.history["val_loss"],label = "Validation Loss", color = "darkred", linestyle="dashed",markeredgecolor = "purple", markeredgewidth = 2)
?    plt.title("Model Loss", color = "darkred", size = 13)
?    plt.legend()
?    plt.show()
?    

    #展示精確模型結(jié)果
    plt.figure()
    plt.plot(hist.history["accuracy"],label = "Train Accuracy", color = "black")
    plt.plot(hist.history["val_accuracy"],label = "Validation Accuracy", color = "darkred", linestyle="dashed",markeredgecolor = "purple", markeredgewidth = 2)
    plt.title("Model Accuracy", color = "darkred", size = 13)
    plt.legend()
    plt.show()


![在這里插入圖片描述](https://img-blog.csdnimg.cn/686ace7db27c4145837ec2e09e8ad917.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARGFuQ2hlbmctc3R1ZGlv,size_17,color_FFFFFF,t_70,g_se,x_16)

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

6 識別效果

from tensorflow.keras.models import load_model
import os
import pandas as pd
from keras.preprocessing.image import ImageDataGenerator,img_to_array, load_img
import cv2,matplotlib.pyplot as plt,numpy as np
from keras.preprocessing import image

train_datagen = ImageDataGenerator(rescale= 1./255,
                                    shear_range = 0.3,
                                    horizontal_flip=True,
                                    zoom_range = 0.3)

model = load_model('model_fruits.h5')
batch_size = 32
img = load_img("./Test/Apricot/3_100.jpg",target_size=(100,100))
plt.imshow(img)
plt.show()

array_image = img_to_array(img)
array_image = array_image * 1./255
x = np.expand_dims(array_image, axis=0)
images = np.vstack([x])
classes = model.predict_classes(images, batch_size=10)
print(classes)
train_dir = './Training/'

train_generator = train_datagen.flow_from_directory(
        train_dir,
        target_size= array_image.shape[:2],
        batch_size = batch_size,
        color_mode= "rgb",
        class_mode= "categorical”)
print(train_generator.class_indices)

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

?

?

    fig = plt.figure(figsize=(16, 16))
    axes = []
    files = []
    predictions = []
    true_labels = []
    rows = 5
    cols = 2
# 隨機選擇幾個圖片
def getRandomImage(path, img_width, img_height):
    """function loads a random image from a random folder in our test path"""
    folders = list(filter(lambda x: os.path.isdir(os.path.join(path, x)), os.listdir(path)))
    random_directory = np.random.randint(0, len(folders))
    path_class = folders[random_directory]
    file_path = os.path.join(path, path_class)
    file_names = [f for f in os.listdir(file_path) if os.path.isfile(os.path.join(file_path, f))]
    random_file_index = np.random.randint(0, len(file_names))
    image_name = file_names[random_file_index]
    final_path = os.path.join(file_path, image_name)
    return image.load_img(final_path, target_size = (img_width, img_height)), final_path, path_class

def draw_test(name, pred, im, true_label):
    BLACK = [0, 0, 0]
    expanded_image = cv2.copyMakeBorder(im, 160, 0, 0, 300, cv2.BORDER_CONSTANT, value=BLACK)
    cv2.putText(expanded_image, "predicted: " + pred, (20, 60), cv2.FONT_HERSHEY_SIMPLEX,
        0.85, (255, 0, 0), 2)
    cv2.putText(expanded_image, "true: " + true_label, (20, 120), cv2.FONT_HERSHEY_SIMPLEX,
        0.85, (0, 255, 0), 2)
    return expanded_image
IMG_ROWS, IMG_COLS = 100, 100

# predicting images
for i in range(0, 10):
    path = "./Test"
    img, final_path, true_label = getRandomImage(path, IMG_ROWS, IMG_COLS)
    files.append(final_path)
    true_labels.append(true_label)
    x = image.img_to_array(img)
    x = x * 1./255
    x = np.expand_dims(x, axis=0)
    images = np.vstack([x])
    classes = model.predict_classes(images, batch_size=10)
    predictions.append(classes)

class_labels = train_generator.class_indices
class_labels = {v: k for k, v in class_labels.items()}
class_list = list(class_labels.values())

for i in range(0, len(files)):
    image = cv2.imread(files[i])
    image = draw_test("Prediction", class_labels[predictions[i][0]], image, true_labels[i])
    axes.append(fig.add_subplot(rows, cols, i+1))
    plt.imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
    plt.grid(False)
    plt.axis('off')
plt.show()

競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù),python

7 最后

?? 更多資料, 項目分享:

https://gitee.com/dancheng-senior/postgraduate

到了這里,關(guān)于競賽保研 基于深度學(xué)習(xí)的水果識別 設(shè)計 開題 技術(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 競賽保研 基于生成對抗網(wǎng)絡(luò)的照片上色動態(tài)算法設(shè)計與實現(xiàn) - 深度學(xué)習(xí) opencv python

    競賽保研 基于生成對抗網(wǎng)絡(luò)的照片上色動態(tài)算法設(shè)計與實現(xiàn) - 深度學(xué)習(xí) opencv python

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 ?? 基于生成對抗網(wǎng)絡(luò)的照片上色動態(tài)算法設(shè)計與實現(xiàn) 該項目較為新穎,適合作為競賽課題方向,學(xué)長非常推薦! ??學(xué)長這里給一個題目綜合評分(每項滿分5分) 難度系數(shù):3分 工作量:3分 創(chuàng)新點:4分 ?? 更多資料, 項目分享: http

    2024年01月17日
    瀏覽(26)
  • 競賽項目 深度學(xué)習(xí)的水果識別 opencv python

    競賽項目 深度學(xué)習(xí)的水果識別 opencv python

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 ?? 深度學(xué)習(xí)的水果識別 opencv python 該項目較為新穎,適合作為競賽課題方向,學(xué)長非常推薦! ??學(xué)長這里給一個題目綜合評分(每項滿分5分) 難度系數(shù):3分 工作量:3分 創(chuàng)新點:4分 ?? 更多資料, 項目分享: https://gitee.com/dancheng-se

    2024年02月13日
    瀏覽(95)
  • 競賽保研 python 機器視覺 車牌識別 - opencv 深度學(xué)習(xí) 機器學(xué)習(xí)

    競賽保研 python 機器視覺 車牌識別 - opencv 深度學(xué)習(xí) 機器學(xué)習(xí)

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 ?? 基于python 機器視覺 的車牌識別系統(tǒng) ??學(xué)長這里給一個題目綜合評分(每項滿分5分) 難度系數(shù):3分 工作量:3分 創(chuàng)新點:3分 ?? 更多資料, 項目分享: https://gitee.com/dancheng-senior/postgraduate 車牌識別其實是個經(jīng)典的機器視覺任務(wù)了,

    2024年02月04日
    瀏覽(29)
  • 競賽保研 基于深度學(xué)習(xí)的目標檢測算法

    競賽保研 基于深度學(xué)習(xí)的目標檢測算法

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 基于深度學(xué)習(xí)的目標檢測算法 該項目較為新穎,適合作為競賽課題方向,學(xué)長非常推薦! ?? 更多資料, 項目分享: https://gitee.com/dancheng-senior/postgraduate 普通的深度學(xué)習(xí)監(jiān)督算法主要是用來做分類,如圖1所示,分類的目標是要識別出圖

    2024年02月02日
    瀏覽(88)
  • 競賽保研 基于深度學(xué)習(xí)的視頻多目標跟蹤實現(xiàn)

    競賽保研 基于深度學(xué)習(xí)的視頻多目標跟蹤實現(xiàn)

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 基于深度學(xué)習(xí)的視頻多目標跟蹤實現(xiàn) 該項目較為新穎,適合作為競賽課題方向,學(xué)長非常推薦! ?? 更多資料, 項目分享: https://gitee.com/dancheng-senior/postgraduate 基于初始化幀的跟蹤,在視頻第一幀中選擇你的目標,之后交給跟蹤算法去

    2024年01月22日
    瀏覽(85)
  • 競賽保研 基于深度學(xué)習(xí)的人臉專注度檢測計算系統(tǒng) - opencv python cnn

    競賽保研 基于深度學(xué)習(xí)的人臉專注度檢測計算系統(tǒng) - opencv python cnn

    ?? 優(yōu)質(zhì)競賽項目系列,今天要分享的是 ?? 基于深度學(xué)習(xí)的人臉專注度檢測計算算法 該項目較為新穎,適合作為競賽課題方向,學(xué)長非常推薦! ??學(xué)長這里給一個題目綜合評分(每項滿分5分) 難度系數(shù):3分 工作量:3分 創(chuàng)新點:5分 ?? 更多資料, 項目分享: https://gitee.co

    2024年02月02日
    瀏覽(904)
  • python基于深度學(xué)習(xí)的水果識別系統(tǒng)

    python基于深度學(xué)習(xí)的水果識別系統(tǒng)

    具體實現(xiàn)分為以下幾個步驟: 數(shù)據(jù)集準備:從互聯(lián)網(wǎng)上采集水果圖片,并將其劃分成訓(xùn)練集、驗證集和測試集,以便用來訓(xùn)練和測試模型。 模型構(gòu)建:使用 PyTorch 來構(gòu)建深度學(xué)習(xí)模型,常用的有 AlexNet、VGG、ResNet 等。根據(jù)實驗情況,可以選擇不同的模型。 訓(xùn)練模型:使用準

    2024年02月07日
    瀏覽(94)
  • 【畢業(yè)設(shè)計】深度學(xué)習(xí)水果識別系統(tǒng) - python CNN

    【畢業(yè)設(shè)計】深度學(xué)習(xí)水果識別系統(tǒng) - python CNN

    ?? Hi,大家好,這里是丹成學(xué)長的畢設(shè)系列文章! ?? 對畢設(shè)有任何疑問都可以問學(xué)長哦! 這兩年開始,各個學(xué)校對畢設(shè)的要求越來越高,難度也越來越大… 畢業(yè)設(shè)計耗費時間,耗費精力,甚至有些題目即使是專業(yè)的老師或者碩士生也需要很長時間,所以一旦發(fā)現(xiàn)問題,一定

    2023年04月13日
    瀏覽(22)
  • 基于python深度學(xué)習(xí)的水果或其他物體識別小程序

    基于python深度學(xué)習(xí)的水果或其他物體識別小程序

    效果圖如下: 代碼演示和demo倉庫看b站視頻003期: 到此一游7758258的個人空間_嗶哩嗶哩_bilibili 代碼展示: 數(shù)據(jù)集圖片放置在data文件夾下,大家可以根據(jù)自己需要比如識別其他物體,只需要模仿data文件夾下的文件命名放入圖片即可運行訓(xùn)練模型了。 ? ?運行01數(shù)據(jù)集文本生成

    2024年02月04日
    瀏覽(81)
  • 基于深度學(xué)習(xí)的水果檢測與識別系統(tǒng)(Python界面版,YOLOv5實現(xiàn))

    基于深度學(xué)習(xí)的水果檢測與識別系統(tǒng)(Python界面版,YOLOv5實現(xiàn))

    摘要:本博文介紹了一種基于深度學(xué)習(xí)的水果檢測與識別系統(tǒng),使用YOLOv5算法對常見水果進行檢測和識別,實現(xiàn)對圖片、視頻和實時視頻中的水果進行準確識別。博文詳細闡述了算法原理,同時提供Python實現(xiàn)代碼、訓(xùn)練數(shù)據(jù)集,以及基于PyQt的UI界面。通過YOLOv5實現(xiàn)對圖像中存

    2024年02月02日
    瀏覽(93)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包