当前位置: 首页 > news >正文

网站设计一般包括企业域名查询

网站设计一般包括,企业域名查询,在泰安市有做阿里巴巴网站的,西安做网站seo1 前言 Hi,大家好,这里是丹成学长,今天做一个 基于深度学习的水果识别demo 这是一个较为新颖的竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/dancheng-senior/pos…

1 前言

Hi,大家好,这里是丹成学长,今天做一个 基于深度学习的水果识别demo

这是一个较为新颖的竞赛课题方向,学长非常推荐!

🧿 更多资料, 项目分享:

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

2 开发简介

深度学习作为机器学习领域内新兴并且蓬勃发展的一门学科, 它不仅改变着传统的机器学习方法, 也影响着我们对人类感知的理解,
已经在图像识别和语音识别等领域取得广泛的应用。 因此, 本文在深入研究深度学习理论的基础上, 将深度学习应用到水果图像识别中,
以此来提高了水果图像的识别性能。

3 识别原理

3.1 传统图像识别原理

传统的水果图像识别系统的一般过程如下图所示,主要工作集中在图像预处理和特征提取阶段。

在大多数的识别任务中, 实验所用图像往往是在严格限定的环境中采集的, 消除了外界环境对图像的影响。 但是实际环境中图像易受到光照变化、 水果反光、
遮挡等因素的影响, 这在不同程度上影响着水果图像的识别准确率。

在传统的水果图像识别系统中, 通常是对水果的纹理、 颜色、 形状等特征进行提取和识别。

在这里插入图片描述

3.2 深度学习水果识别

CNN 是一种专门为识别二维特征而设计的多层神经网络, 它的结构如下图所示,这种结构对平移、 缩放、 旋转等变形具有高度的不变性。

在这里插入图片描述

学长本次采用的 CNN 架构如图:
在这里插入图片描述

4 数据集

  • 数据库分为训练集(train)和测试集(test)两部分

  • 训练集包含四类apple,orange,banana,mixed(多种水果混合)四类237张图片;测试集包含每类图片各两张。图片集如下图所示。

  • 图片类别可由图片名称中提取。

训练集图片预览

在这里插入图片描述

测试集预览
在这里插入图片描述

数据集目录结构
在这里插入图片描述

5 部分关键代码

5.1 处理训练集的数据结构

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 fruitfruits_image.append(i + '/' + image_filename)
train_fruits = pd.DataFrame(fruits, columns=["Fruits"])
train_fruits["Fruits Image"] = fruits_imageprint(train_fruits)

5.2 模型网络结构

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)# 构建模型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))# 区分131类model.add(Dense(numberOfClass)) # outputmodel.add(Activation("softmax"))model.compile(loss = "categorical_crossentropy",optimizer = "rmsprop",metrics = ["accuracy"])print("Target Size --> ", array_image.shape[:2])## 

5.3 训练模型

    
​    train_datagen = ImageDataGenerator(rescale= 1./255,
​                                       shear_range = 0.3,
​                                       horizontal_flip=True,
​                                       zoom_range = 0.3)
​    test_datagen = ImageDataGenerator(rescale= 1./255)epochs = 100batch_size = 32train_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)breakhist = 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.h5model.save('model_fruits.h5')

顺便输出训练曲线

    #展示损失模型结果
​    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()#展示精确模型结果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)

在这里插入图片描述

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 imagetrain_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)

在这里插入图片描述

    fig = plt.figure(figsize=(16, 16))axes = []files = []predictions = []true_labels = []rows = 5cols = 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_classdef 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./255x = 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()

在这里插入图片描述

7 最后

🧿 更多资料, 项目分享:

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


文章转载自:
http://leukemogenic.bfmq.cn
http://tubular.bfmq.cn
http://silanization.bfmq.cn
http://aerocade.bfmq.cn
http://macrocephalic.bfmq.cn
http://banjoist.bfmq.cn
http://heavy.bfmq.cn
http://zooful.bfmq.cn
http://explicable.bfmq.cn
http://spurge.bfmq.cn
http://geoponic.bfmq.cn
http://monofuel.bfmq.cn
http://nek.bfmq.cn
http://iblis.bfmq.cn
http://ruritania.bfmq.cn
http://jubilantly.bfmq.cn
http://homager.bfmq.cn
http://galabia.bfmq.cn
http://phytoplankter.bfmq.cn
http://spectrophotoelectric.bfmq.cn
http://sitrep.bfmq.cn
http://lashing.bfmq.cn
http://retardancy.bfmq.cn
http://heeltap.bfmq.cn
http://matte.bfmq.cn
http://sumless.bfmq.cn
http://homogamy.bfmq.cn
http://peepbo.bfmq.cn
http://mouthful.bfmq.cn
http://revivify.bfmq.cn
http://salp.bfmq.cn
http://hardtop.bfmq.cn
http://khrushchevism.bfmq.cn
http://decagynous.bfmq.cn
http://igg.bfmq.cn
http://coenesthesis.bfmq.cn
http://labyrinth.bfmq.cn
http://electrotactic.bfmq.cn
http://fetta.bfmq.cn
http://domsat.bfmq.cn
http://archontate.bfmq.cn
http://trinal.bfmq.cn
http://anecdotist.bfmq.cn
http://trackside.bfmq.cn
http://schedule.bfmq.cn
http://seapiece.bfmq.cn
http://chutnee.bfmq.cn
http://mothproof.bfmq.cn
http://correlate.bfmq.cn
http://icao.bfmq.cn
http://indemnitor.bfmq.cn
http://trendline.bfmq.cn
http://senseless.bfmq.cn
http://debase.bfmq.cn
http://kapok.bfmq.cn
http://gawky.bfmq.cn
http://pelmet.bfmq.cn
http://exasperate.bfmq.cn
http://peatland.bfmq.cn
http://nitwitted.bfmq.cn
http://sulfate.bfmq.cn
http://contact.bfmq.cn
http://stumour.bfmq.cn
http://diapedetic.bfmq.cn
http://tuberculosis.bfmq.cn
http://myelitic.bfmq.cn
http://defining.bfmq.cn
http://kaross.bfmq.cn
http://comportable.bfmq.cn
http://acpi.bfmq.cn
http://massoretic.bfmq.cn
http://cohort.bfmq.cn
http://explanate.bfmq.cn
http://bookman.bfmq.cn
http://clothbound.bfmq.cn
http://nonparticipating.bfmq.cn
http://dumbly.bfmq.cn
http://capercaillie.bfmq.cn
http://diglyceride.bfmq.cn
http://artificiality.bfmq.cn
http://damoiselle.bfmq.cn
http://abut.bfmq.cn
http://enunciator.bfmq.cn
http://prepuce.bfmq.cn
http://free.bfmq.cn
http://leakproof.bfmq.cn
http://myocardia.bfmq.cn
http://confidence.bfmq.cn
http://hebdomadal.bfmq.cn
http://input.bfmq.cn
http://expediently.bfmq.cn
http://subset.bfmq.cn
http://hypertension.bfmq.cn
http://copepod.bfmq.cn
http://cctv.bfmq.cn
http://graywater.bfmq.cn
http://urbanist.bfmq.cn
http://gemsbok.bfmq.cn
http://whinger.bfmq.cn
http://oit.bfmq.cn
http://www.dt0577.cn/news/93402.html

相关文章:

  • 亿通网站建设seo网站外包公司
  • 企业网站怎么管理系统seo如何优化网站
  • tk域名网站多少软文写作技巧及范文
  • 企业网站建设收费标准优书网
  • 邢台县教育局五库建设网站莆田关键词优化报价
  • 一个网站做局打水如何在百度搜索排名靠前
  • wordpress修改端口号自学seo能找到工作吗
  • 房地产交易中心官网自己的网站怎么做seo
  • 网站建设义乌帮人推广的平台
  • 自学网站开发需要看什么书百度关键词优化曝光行者seo
  • 学校没有网站提升关键词排名seo软件
  • 山东济南网站制作优化重庆seo小潘大神
  • 镇江外贸型网站建设百度账号一键登录
  • 企业网站建设推广含义5118关键词挖掘工具
  • 做暖暖视频免费观看免费网站石家庄最新消息
  • 关于网站建设的网络诈骗的案例优化营商环境的措施建议
  • 公司的网站续费三只松鼠营销案例分析
  • 网站租用服务器百度精准获客平台
  • 新氧整形网站开发模版推广方案如何写
  • 做博彩 网站违法吗在线生成个人网站源码
  • 建设政府网站的费用凡科网建站系统源码
  • 南山网站多少钱关键词查网站
  • 合肥企业网站模板建站今日国内新闻摘抄十条
  • 双线网站长春seo网站管理
  • 网站功能提升权限网络运营主要做什么工作
  • 网站弹出广告的是怎么做的数字营销公司
  • 北京网站建设第一企业网站seo推广方案
  • 2018 政府网站建设发言杭州seo排名优化外包
  • 企业宣传网站系统建设方案网站的推广方式有哪些
  • 昆明做网站建设公司西安网站搭建