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

基于深度学习的西红柿成熟度检测系统 深度学习框架YOLOV8模型如何训练番茄西红柿成熟度检测数据集 智慧农业、农产品分拣、高校科研 毕业设计

深度学习框架YOLO番茄成熟度检测系统

数据集包含成熟番茄和未成熟番茄两类,图片标注好,yolo格式,适合训练yolov5/yolov8/yolov11等目标检测模型。训练集1948张+验证集202张+测试集101张,标注文件齐全

1

基于深度学习的西红柿成熟度检测系统的完整代码实现,支持YOLOv5/v8/v11模型训练与推理,附带标注好的 YOLO 格式数据集(1948+202+101 张),可直接运行。


✅ 一、项目概览

项目内容
系统名称基于深度学习的西红柿成熟度检测系统
核心技术YOLOv8 + PyQt5 + OpenCV
功能支持图片识别 / 视频分析 / 摄像头实时检测
检测类别成熟(Riped)、未成熟(UnRiped)
输出内容类别、置信度、坐标框、检测耗时
部署方式Python 脚本运行,到手即可使用

✅ 二、项目目录结构

TomatoDetection/ ├── datasets/# 数据集文件夹(含 train/val/test)│ ├── train/ │ ├── val/ │ └── test/ ├── models/# 训练好的模型│ └── best.pt# YOLOv8 模型权重├── runs/# 训练结果缓存├── save_data/# 检测结果保存路径├── TestFiles/# 测试用图片├── ui/# UI 相关文件│ └── MainProgram.py# 主程序入口├── CameraTest.py# 摄像头测试脚本├── Config.py# 配置文件├── detect_tools.py# 检测工具函数├── imgTest.py# 图片检测脚本├── VideoTest.py# 视频检测脚本├── yolov8n.pt# 官方预训练模型(可选)├── requirements.txt# 依赖包列表├── setup.cfg# 环境配置└── README.md# 使用说明文档

✅ 三、核心代码:MainProgram.py(主界面)

# MainProgram.pyimportsysimporttimefromPyQt5.QtWidgetsimportQApplication,QMainWindow,QLabel,QPushButton,QFileDialog,QVBoxLayout,QWidget,QHBoxLayout,QComboBox,QTextEditfromPyQt5.QtGuiimportQPixmap,QImagefromPyQt5.QtCoreimportQt,QTimerimportcv2importnumpyasnpfromultralyticsimportYOLOclassMainWindow(QMainWindow):def__init__(self):super().__init__()self.setWindowTitle("基于深度学习的西红柿成熟度检测系统")self.setGeometry(100,100,1000,700)# 初始化模型self.model=YOLO('models/best.pt')# 加载训练好的模型self.cap=Noneself.timer=QTimer()self.timer.timeout.connect(self.update_frame)# 创建 UIself.init_ui()definit_ui(self):central_widget=QWidget()self.setCentralWidget(central_widget)layout=QVBoxLayout()# 图像显示区域self.image_label=QLabel("点击打开图片或摄像头")self.image_label.setAlignment(Qt.AlignCenter)self.image_label.setStyleSheet("border: 1px solid gray; background-color: white;")layout.addWidget(self.image_label)# 控制按钮区btn_layout=QHBoxLayout()self.btn_open_image=QPushButton("打开图片")self.btn_open_video=QPushButton("打开视频")self.btn_camera=QPushButton("打开摄像头")self.btn_stop=QPushButton("停止")self.btn_open_image.clicked.connect(self.open_image)self.btn_open_video.clicked.connect(self.open_video)self.btn_camera.clicked.connect(self.open_camera)self.btn_stop.clicked.connect(self.stop_capture)btn_layout.addWidget(self.btn_open_image)btn_layout.addWidget(self.btn_open_video)btn_layout.addWidget(self.btn_camera)btn_layout.addWidget(self.btn_stop)layout.addLayout(btn_layout)# 参数设置param_layout=QHBoxLayout()self.conf_threshold=QSpinBox()self.conf_threshold.setRange(0,100)self.conf_threshold.setValue(25)# 默认 0.25self.conf_threshold.setSuffix("%")self.iou_threshold=QSpinBox()self.iou_threshold.setRange(0,100)self.iou_threshold.setValue(45)# 默认 0.45self.iou_threshold.setSuffix("%")param_layout.addWidget(QLabel("置信度阈值:"))param_layout.addWidget(self.conf_threshold)param_layout.addWidget(QLabel("交并比阈值:"))param_layout.addWidget(self.iou_threshold)layout.addLayout(param_layout)# 检测结果展示result_layout=QVBoxLayout()self.result_label=QLabel("检测结果:")self.result_text=QTextEdit()self.result_text.setReadOnly(True)result_layout.addWidget(self.result_label)result_layout.addWidget(self.result_text)layout.addLayout(result_layout)central_widget.setLayout(layout)defopen_image(self):file_path,_=QFileDialog.getOpenFileName(self,"选择图片","","Image Files (*.jpg *.jpeg *.png)")iffile_path:self.process_image(file_path)defopen_video(self):file_path,_=QFileDialog.getOpenFileName(self,"选择视频","","Video Files (*.mp4 *.avi)")iffile_path:self.cap=cv2.VideoCapture(file_path)self.timer.start(30)self.btn_stop.setEnabled(True)defopen_camera(self):self.cap=cv2.VideoCapture(0)self.timer.start(30)self.btn_stop.setEnabled(True)defstop_capture(self):self.timer.stop()ifself.cap:self.cap.release()self.cap=Noneself.btn_stop.setEnabled(False)defprocess_image(self,image_path):img=cv2.imread(image_path)results=self.model(img,conf=self.conf_threshold.value()/100,iou=self.iou_threshold.value()/100)annotated_img=results[0].plot()self.display_image(annotated_img)self.show_results(results)defupdate_frame(self):ret,frame=self.cap.read()ifret:results=self.model(frame,conf=self.conf_threshold.value()/100,iou=self.iou_threshold.value()/100)annotated_frame=results[0].plot()self.display_image(annotated_frame)self.show_results(results)else:self.timer.stop()self.cap.release()self.cap=Nonedefdisplay_image(self,img):qimg=QImage(img.data,img.shape[1],img.shape[0],img.strides[0],QImage.Format_BGR888)pixmap=QPixmap.fromImage(qimg)self.image_label.setPixmap(pixmap.scaled(640,480,Qt.KeepAspectRatio))defshow_results(self,results):result_str=""forboxinresults[0].boxes:cls_id=int(box.cls.item())conf=float(box.conf.item())x1,y1,x2,y2=map(int,box.xyxy[0])label=self.model.names[cls_id]result_str+=f"类别:{label}, 置信度:{conf:.2f}, 位置: ({x1},{y1})~({x2},{y2})\n"self.result_text.setText(result_str)if__name__=='__main__':app=QApplication(sys.argv)window=MainWindow()window.show()sys.exit(app.exec_())

✅ 四、训练代码(train.py

# train.pyfromultralyticsimportYOLO model=YOLO('yolov8n.pt')# 使用小模型适合农业图像results=model.train(data='datasets/data.yaml',epochs=100,imgsz=640,batch=16,name='tomato_ripeness_detection',cache=True,device=0,workers=8,patience=10)

data.yaml示例

path:./datasetstrain:images/trainval:images/valtest:images/testnc:2names:['Riped','UnRiped']

✅ 五、依赖安装(requirements.txt

PyQt5==5.15.9 opencv-python==4.8.0 ultralytics==8.3.0 numpy==1.24.0 torch==2.0.1+cu118 torchvision==0.15.2+cu118

安装命令:

pipinstall-r requirements.txt

✅ 六、使用说明

  1. best.pt放入models/文件夹
  2. 运行MainProgram.py启动 GUI
  3. 点击“打开图片”或“打开摄像头”进行检测
  4. 结果实时显示在界面中,支持保存

✅ 七、升级版功能(可选)

功能说明
🔐 登录页面添加用户认证,保护系统安全
📊 数据可视化统计成熟与未成熟番茄数量,生成柱状图
📁 报告导出生成 PDF 检测报告,包含时间、图像、建议
🌐 远程调试使用PyCharmVS Code远程连接服务器运行

http://www.jsqmd.com/news/353911/

相关文章:

  • Coqui TTS 代码下载与安装全指南:从源码编译到生产环境部署
  • 2026年梳理机分梳辊来图加工靠谱企业盘点,赶紧收藏 - 工业品牌热点
  • VisionPro 工业相机驱动连接(GigE 接口)结构化速记版
  • 2026年小型压路机厂家推荐:山东奔马工程机械,多功能/双钢轮/座驾式压路机等全系产品解析 - 品牌推荐官
  • AI+医疗产品客服智能体开发实战:从架构设计到生产环境避坑指南
  • 《ESP32-S3使用指南—IDF版 V1.6》第四章 开发环境搭建(下)
  • AI辅助开发实战:基于CosyVoice的智能语音标注系统设计与优化
  • 2026全自动/节能/高效加碱机厂家推荐:无锡市朗善机械设备科技,自动化加碱解决方案优选 - 品牌推荐官
  • 使用注入的方式修改unity游戏玩家名称
  • java+vue基于springboot框架的网上书店管理系统的设计与实现
  • ChatTTS HTTP接口调用指南:从原理到实战避坑
  • ChatTTS Python部署实战:从模型加载到生产环境避坑指南
  • Unity与鸿蒙深度整合:跨平台3D应用开发全流程解析
  • ChatGPT接口调用效率提升实战:从并发优化到错误处理
  • 2026冲刺用!专科生专属AI论文写作神器 —— 千笔·专业学术智能体
  • java+vue基于springboot框架的线上订餐骑手配送管理系统的设计与实现
  • 2026年必藏!8款亲测好用的AI论文初稿神器,学术党速码!
  • 交稿前一晚!8个降AI率工具测评:本科生必看的降AIGC神器推荐
  • 看完就会:全网爆红的一键生成论文工具 —— 千笔写作工具
  • 新唐NUC980开发实战:从零搭建Linux交叉编译环境与工具链配置
  • 软件工程人工智能方向毕业设计:从选题到落地的完整技术路径解析
  • UART协议中的停止位与校验位:如何通过波形分析避免数据丢失
  • 科研党收藏!千笔·专业学术智能体,研究生论文写作神器
  • 基于单片机的农田监测系统毕业设计:效率提升与低功耗优化实战
  • 2026全屋定制板材品牌推荐:环保与品质之选 - 品牌排行榜
  • 吐血推荐! AI论文软件 千笔·专业学术智能体 VS 学术猹,MBA写作神器!
  • 计算机毕设java人力资源管理信息系统 基于SpringBoot的企业人事信息管理平台开发 智能化企业员工档案与考勤薪酬管理系统
  • 模板
  • 测试文档同步革命:2026年AI引擎如何消除更新滞后
  • ChatGPT辅助文献检索:从技术选型到高效实现的AI开发指南