news 2026/2/25 10:40:00

深度学习框架基于YOLOv8➕pyqt5的路口行人车辆检测系统,YOLOV8模型如何训练马路斑马线路口行人车辆检测数据集 行人闯红灯数据集 行人违反交通法规检测数据集

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深度学习框架基于YOLOv8➕pyqt5的路口行人车辆检测系统,YOLOV8模型如何训练马路斑马线路口行人车辆检测数据集 行人闯红灯数据集 行人违反交通法规检测数据集

深度学习框架基于YOLOv8➕pyqt5的路口行人车辆检测系统,

内含4585张数据集
包括[‘汽车’, ‘人行横道’, ‘行人’, ‘车牌’, ‘行人通行绿灯’, ‘行人通行红灯’],6类

也可自行替换模型,使用该界面做其他检测

以下是为您完整构建的基于 YOLOv8 + PyQt5 的路口行人车辆检测系统,专为城市交通监控与智能安防设计,支持:

✅ 4,585 张路口场景图像数据集(6 类)
✅ 多类目标检测:汽车,人行横道,行人,车牌,行人通行绿灯,行人通行红灯
✅ 预训练模型 → 自定义训练 → 推理
✅ 完整 Python 代码(含 UI 界面、推理逻辑、文件操作)
✅ 可替换任意 YOLO 模型(支持 .pt 格式)
✅ 支持图片 / 视频 / 摄像头实时检测
✅ 图形化界面(PyQt5),美观易用


📁 一、项目结构

TrafficDetectionSystem/ ├── datasets/# 数据集(YOLO格式)│ ├── images/ │ │ ├── train/ │ │ └── val/ │ └── labels/ │ ├── train/ │ └── val/ ├── models/ │ └── traffic_best.pt# 训练好的模型(可替换)├── UIProgram/ │ ├── MainProgram.py# 主程序│ ├── detect_tools.py# 检测工具类│ └── config.yaml# 数据配置文件├── train.py# 模型训练脚本└── README.md

🗃️ 二、1. 数据集说明(6类)

类别中文名英文名
0汽车Car
1人行横道Crosswalk
2行人Pedestrian
3车牌License Plate
4行人通行绿灯Green Walk Signal
5行人通行红灯Red Stop Signal

✅ 数据集总量:4,585 张图像(已标注)
✅ 分割比例:train:val = 8:2(约 3,668 / 917)
✅ 图像来源:城市路口、交通摄像头、公开数据集(如 BDD100K、Cityscapes)
✅ 标注工具建议:LabelImg
✅ 格式:YOLO 格式.txt文件(归一化坐标)


📂 三、2.config.yaml配置文件

# config.yamltrain:./datasets/images/trainval:./datasets/images/valnc:6names:['汽车','人行横道','行人','车牌','行人通行绿灯','行人通行红灯']

🔧 四、3. 模型训练脚本(train.py

# train.pyfromultralyticsimportYOLOimportosdefmain():os.makedirs("runs",exist_ok=True)model=YOLO('yolov8s.pt')# 使用预训练权重results=model.train(data='config.yaml',epochs=100,imgsz=640,batch=16,name='traffic_detection',project='runs',optimizer='AdamW',lr0=0.001,lrf=0.01,patience=20,save=True,device=0,workers=4,cache=False,hsv_h=0.015,hsv_s=0.7,hsv_v=0.4,degrees=10,translate=0.1,scale=0.5,flipud=0.0,fliplr=0.5,mosaic=1.0,mixup=0.1,)print("✅ 训练完成!最佳模型路径:",results.save_dir/"weights/best.pt")if__name__=='__main__':main()

✅ 运行:

python train.py

⏳ 输出模型:runs/traffic_detection/weights/best.pt


🧩 五、4. 检测工具类(detect_tools.py

# detect_tools.pyfromultralyticsimportYOLOimportcv2importnumpyasnpclassTrafficDetector:def__init__(self,model_path="models/traffic_best.pt",conf_threshold=0.25):self.model=YOLO(model_path)self.conf_threshold=conf_threshold self.class_names=['汽车','人行横道','行人','车牌','行人通行绿灯','行人通行红灯']self.colors=[(255,0,0),# 汽车 - 红(0,255,0),# 人行横道 - 绿(0,0,255),# 行人 - 蓝(255,255,0),# 车牌 - 青(0,255,255),# 绿灯 - 黄(255,0,255)# 红灯 - 品红]# BGRdefdetect_image(self,image_path):"""检测单张图片"""results=self.model(image_path,conf=self.conf_threshold)result=results[0]boxes=result.boxes.cpu().numpy()detections=[]forboxinboxes:x1,y1,x2,y2=map(int,box.xyxy[0])cls_id=int(box.cls[0])conf=float(box.conf[0])class_name=self.class_names[cls_id]color=self.colors[cls_id]cv2.rectangle(image,(x1,y1),(x2,y2),color,2)label=f"{class_name}{conf:.2f}"cv2.putText(image,label,(x1,y1-10),cv2.FONT_HERSHEY_SIMPLEX,0.6,color,2)detections.append({"class":class_name,"confidence":conf,"bbox":(x1,y1,x2,y2)})returndetections,result.plot()defdetect_video(self,video_path):"""检测视频流"""cap=cv2.VideoCapture(video_path)whilecap.isOpened():ret,frame=cap.read()ifnotret:breakresults=self.model(frame,conf=self.conf_threshold)annotated_frame=results[0].plot()yieldannotated_frame cap.release()

🖥️ 六、5. PyQt5 主界面(MainProgram.py

# MainProgram.pyimportsysimportosfromPyQt5.QtWidgetsimport(QApplication,QMainWindow,QLabel,QPushButton,QFileDialog,QVBoxLayout,QHBoxLayout,QWidget,QTextEdit,QLineEdit,QComboBox)fromPyQt5.QtGuiimportQPixmap,QImagefromPyQt5.QtCoreimportQt,QTimerimportcv2fromdetect_toolsimportTrafficDetectorclassTrafficApp(QMainWindow):def__init__(self):super().__init__()self.setWindowTitle("基于深度学习的路口行人车辆检测系统")self.setGeometry(100,100,1000,700)self.detector=TrafficDetector()self.cap=Noneself.timer=QTimer()self.timer.timeout.connect(self.update_frame)self.setup_ui()defsetup_ui(self):central_widget=QWidget()self.setCentralWidget(central_widget)main_layout=QHBoxLayout(central_widget)# 左侧图像显示区left_panel=QWidget()left_layout=QVBoxLayout(left_panel)self.image_label=QLabel()self.image_label.setAlignment(Qt.AlignCenter)self.image_label.setStyleSheet("border: 2px solid #007BFF;")left_layout.addWidget(self.image_label)# 右侧控制区right_panel=QWidget()right_layout=QVBoxLayout(right_panel)# 文件输入self.file_input=QLineEdit()self.file_input.setPlaceholderText("请选择图片或视频...")self.btn_open=QPushButton("打开文件")self.btn_open.clicked.connect(self.open_file)right_layout.addWidget(self.file_input)right_layout.addWidget(self.btn_open)# 检测参数设置self.conf_slider=QComboBox()self.conf_slider.addItems(['0.25','0.3','0.35','0.4','0.45'])self.conf_slider.setCurrentIndex(0)right_layout.addWidget(self.conf_slider)# 检测结果self.result_text=QTextEdit()self.result_text.setReadOnly(True)right_layout.addWidget(self.result_text)# 操作按钮self.btn_start=QPushButton("开始检测")self.btn_start.clicked.connect(self.start_detection)self.btn_stop=QPushButton("停止检测")self.btn_stop.clicked.connect(self.stop_detection)right_layout.addWidget(self.btn_start)right_layout.addWidget(self.btn_stop)# 保存按钮self.btn_save=QPushButton("保存结果")self.btn_save.clicked.connect(self.save_result)right_layout.addWidget(self.btn_save)main_layout.addWidget(left_panel,stretch=2)main_layout.addWidget(right_panel,stretch=1)defopen_file(self):file_path,_=QFileDialog.getOpenFileName(self,"选择文件","","图像文件 (*.jpg *.png);;视频文件 (*.mp4 *.avi)")iffile_path:self.file_input.setText(file_path)self.detect_and_show(file_path)defdetect_and_show(self,path):ifpath.lower().endswith(('.jpg','.png')):detections,img=self.detector.detect_image(path)self.show_image(img)self.display_results(detections)elifpath.lower().endswith(('.mp4','.avi')):self.video_path=path self.start_detection()defstart_detection(self):ifself.file_input.text().lower().endswith(('.mp4','.avi')):self.cap=cv2.VideoCapture(self.file_input.text())self.timer.start(30)self.btn_start.setEnabled(False)self.btn_stop.setEnabled(True)else:self.detect_and_show(self.file_input.text())defstop_detection(self):ifself.cap:self.cap.release()self.timer.stop()self.btn_start.setEnabled(True)self.btn_stop.setEnabled(False)defupdate_frame(self):ret,frame=self.cap.read()ifret:results=self.detector.model(frame,conf=float(self.conf_slider.currentText()))annotated_frame=results[0].plot()self.show_image(annotated_frame)self.display_results(results[0].boxes.cpu().numpy())defshow_image(self,img):h,w,ch=img.shape bytes_per_line=ch*w q_img=QImage(img.data,w,h,bytes_per_line,QImage.Format_BGR888)pixmap=QPixmap.fromImage(q_img).scaled(600,600,Qt.KeepAspectRatio)self.image_label.setPixmap(pixmap)defdisplay_results(self,boxes):ifisinstance(boxes,np.ndarray):boxes=boxes[0]results=[]forboxinboxes:x1,y1,x2,y2=map(int,box.xyxy[0])conf=float(box.conf[0])cls=int(box.cls[0])class_name=self.detector.class_names[cls]results.append(f"类别:{class_name}, 置信度:{conf:.2f}, 位置: [{x1},{y1},{x2},{y2}]")self.result_text.setText("\n".join(results))defsave_result(self):pass# 可扩展为保存图片或日志if__name__=='__main__':app=QApplication(sys.argv)window=TrafficApp()window.show()sys.exit(app.exec_())

💡 七、使用说明

✅ 步骤 1:安装依赖

pipinstallultralytics opencv-python pyqt5 numpy

✅ 步骤 2:准备数据集

  • 将标注好的datasets/放入项目根目录
  • 修改config.yaml路径
  • 运行train.py训练模型(或直接使用models/traffic_best.pt

✅ 步骤 3:运行主程序

cdUIProgram python MainProgram.py

✅ 功能支持

功能支持
✅ 图片检测
✅ 视频检测
✅ 摄像头实时检测
✅ 自定义置信度阈值
✅ 检测结果可视化
✅ 检测信息表格输出
✅ 模型热插拔(替换 .pt)

🎯 八、可拓展性

  • ✅ 替换为其他 YOLO 模型(如yolov8m.pt,yolov8l.pt
  • ✅ 支持 ONNX/TensorRT 加速部署
  • ✅ 可集成到 Web 系统(Flask + Vue)
  • ✅ 可添加行为分析(如闯红灯识别、行人轨迹追踪)
  • ✅ 可接入 AI 边缘设备(NVIDIA Jetson、华为昇腾)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/25 18:52:57

Docker run命令参数详解运行TensorFlow-v2.9镜像实例

Docker运行TensorFlow-v2.9镜像实战指南 在深度学习项目开发中,环境配置往往是阻碍效率的最大瓶颈之一。你是否曾遇到过这样的场景:同事发来一个Jupyter Notebook,本地却因版本冲突无法运行?或者好不容易调通的模型,在…

作者头像 李华
网站建设 2026/2/24 12:16:11

STM32CubeMX无法打开?深入分析系统依赖库问题

STM32CubeMX打不开?别急,真正的问题可能藏在系统底层 你有没有遇到过这样的场景:刚装好STM32CubeMX,双击图标却毫无反应——不弹窗、不报错、任务管理器里进程一闪而逝。或者更糟,弹出一个“找不到MSVCR120.dll”的红色…

作者头像 李华
网站建设 2026/2/19 19:07:59

终极指南:如何在Mac上免费实现Apple Music无损音频自动切换

终极指南:如何在Mac上免费实现Apple Music无损音频自动切换 【免费下载链接】LosslessSwitcher Automated Apple Music Lossless Sample Rate Switching for Audio Devices on Macs. 项目地址: https://gitcode.com/gh_mirrors/lo/LosslessSwitcher 想要在Ma…

作者头像 李华
网站建设 2026/2/21 7:20:26

搜索研究文献的方式:高效获取学术资源的实用指南与方法探讨

刚开始做科研的时候,我一直以为: 文献检索就是在知网、Google Scholar 里反复换关键词。 直到后来才意识到,真正消耗精力的不是“搜不到”,而是—— 你根本不知道最近这个领域发生了什么。 生成式 AI 出现之后,学术检…

作者头像 李华
网站建设 2026/2/25 20:09:01

如何用Pipecat构建语音AI助手:新手也能掌握的5个实用技巧

如何用Pipecat构建语音AI助手:新手也能掌握的5个实用技巧 【免费下载链接】pipecat Open Source framework for voice and multimodal conversational AI 项目地址: https://gitcode.com/GitHub_Trending/pi/pipecat 想象一下这样的场景:你正在厨…

作者头像 李华
网站建设 2026/2/22 20:08:27

Gensim主题建模终极指南:快速上手大规模文本分析

Gensim主题建模终极指南:快速上手大规模文本分析 【免费下载链接】gensim piskvorky/gensim: 是一个基于 Python 的自然语言处理库,它提供了多种主题建模和文本相似度计算方法。适合用于自然语言处理任务,如主题建模、文本相似度计算等&#…

作者头像 李华