YOLOV8 OpenCV + usb 相机 实时识别

server/2025/2/11 16:02:07/

0、STM32 上位机通信

STM32 上位机通信

1、OpenCV 读相机

import cv2cap = cv2.VideoCapture(0)
while (1):# get a frameret, frame = cap.read()# show a framecv2.imshow("capture", frame)if cv2.waitKey(1) & 0xFF == ord('q'):# cv2.imwrite("/opt/code/image/fangjian2.jpeg", frame)#passbreak
cap.release()
cv2.destroyAllWindows()

在这里插入图片描述

2、yolov8推理

from ultralytics import  YOLO
model =YOLO('yolov8n.pt')result = model.predict('dog.jpg',imgsz = 640,show = True)

3、 yolov8 实时推理相机图片

 
from ultralytics import  YOLOimport cv2def get_img(cap):while (1):# get a frameret, frame = cap.read()# show a frame# cv2.imshow("capture", frame)# if cv2.waitKey(1) & 0xFF == ord('q'):#    # cv2.imwrite("/opt/code/image/fangjian2.jpeg", frame)#    #pass#    breakreturn frame
m_cap = cv2.VideoCapture(0)
model =YOLO('yolov8n.pt')
# 输出检测结果和坐标
while True:img = get_img(m_cap)cv2.imshow("capture", img)cv2.waitKey(1)#results = model.predict(img)results = model.predict(img)annotated_frame = results[0].plot()cv2.imshow("YOLOv8 Tracking", annotated_frame)cv2.waitKey(1)

4、 result

在这里插入图片描述

5、 PS

总结,在一台老旧的电脑上
在这里插入图片描述
跑yolov8 n 感觉速度可以
在这里插入图片描述
识别精度也还凑合

6、 yolo v8 输出检测框坐标

import cv2
import os
from ultralytics import YOLO
import random
# 加载YOLOv8模型
#model = YOLO('yolov8n.pt')model = YOLO('../runs/detect/train6/weights/last.pt')# 打开视频文件
##--
frame = cv2.imread("I:/motor/fruit/" + str(7888) + '.jpg')
cv2.imshow('22', frame)
cv2.waitKey(0)
video_path = os.path.join('.', 'data', 'people.mp4')
fourcc = cv2.VideoWriter_fourcc(*'XVID')
cap_out = cv2.VideoWriter('testwrite.avi', fourcc, 10.0, (1920, 1080), True)
dic = {0: 'Pome', 1: 'Pear'}
colors = [ (255, 50, 255),(255, 0, 0)]
detection_threshold = 0.5
i = 7888
while i < 8050:i += 1frame = cv2.imread("I:/motor/fruit/" + str(i) + '.jpg')results = model(frame)for result in results:detections = []for r in result.boxes.data.tolist():x1, y1, x2, y2, score, class_id = rx1 = int(x1)x2 = int(x2)y1 = int(y1)y2 = int(y2)class_id = int(class_id)cv2.rectangle(frame, (int(x1), int(y1)), (int(x2), int(y2)), (colors[class_id % len(colors)]), 3)cv2.putText(frame, dic[class_id], (x1-10,y1-10), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (colors[class_id % len(colors)]), 2)cv2.putText(frame, '('+str(x1)+','+str(y1)+')', (x1+100, y1+100), cv2.FONT_HERSHEY_SIMPLEX, 0.75,(colors[class_id % len(colors)]), 2)cv2.waitKey(2)cv2.imshow('0', frame)cap_out.write(frame)if score > detection_threshold:detections.append([x1, y1, x2, y2, score])cap_out.write(frame)cap_out.release()
cv2.destroyAllWindows()

7、 利用yolo v8 输出检测框坐标把物体推入到收纳盒

在这里插入图片描述


http://www.ppmy.cn/server/166421.html

相关文章

为什么mysql默认RR(repeat read可重复读)隔离级别

为什么默认设置rr?: 隔离级别\解决问题脏读不可重复读幻读读未提交OOO读提交❌OO重复读❌❌序列化❌❌❌ 脏读&#xff1a; 某个事务已更新一份数据&#xff0c;另一个事务在此时读取了 同一份数据&#xff0c;由于某些原因&#xff0c;前一个RollBack操作了操作&#xff0c;…

秒杀系统设计总结

文章目录 系统架构访问层优化中间转发层与限流服务端利用Redis数据库优化并发控制与数据一致性安全防护监控与报警 系统架构 微服务架构&#xff1a;将复杂的秒杀系统拆分为多个独立的微服务&#xff0c;如用户服务、商品服务、订单服务、秒杀服务等。每个微服务专注于特定业务…

程序猿成长之路之数据挖掘篇——决策树分类算法(2)——构建决策树

上次讲到信息熵和信息增益&#xff0c;讲了理论知识现在让我们构建决策树 1. 树的基本知识 二叉树&#xff1a;一棵树由根节点和子节点组成&#xff0c;子节点又分为叶子节点和非叶子节点&#xff0c;每个非叶子节点都由两个分支组成&#xff0c;分别为该节点的左、右子树。其二…

【含文档+PPT+源码】基于微信小程序的校园志愿者管理系统的设计与实现

项目介绍 本课程演示的是一款 基于微信小程序的校园志愿者管理系统的设计与实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本…

Node.js 实现简单爬虫

介绍 爬虫是一种按照一定的规则&#xff0c;自动地抓取万维网信息的程序或者脚本。 本文将使用 Nodejs 编写一个简单的爬虫脚本&#xff0c;爬取一个美食网站&#xff0c;获取菜品的标题和图片链接&#xff0c;并以表格的形式输出。 准备工作 1、初始化项目 首先&#xff0…

神经网络的数据流动过程(张量的转换和输出)

文章目录 1、文本从输入到输出&#xff0c;经历了什么&#xff1f;2、数据流动过程是张量&#xff0c;如何知道张量表达的文本内容&#xff1f;3、词转为张量、张量转为词是唯一的吗&#xff1f;为什么&#xff1f;4、如何保证词张量的质量和合理性5、总结 &#x1f343;作者介…

DeepSeek模拟阿里面试官——java基础(面向对象)

作为一位阿里高级Java程序员面试官&#xff0c;我会围绕Java面向对象编程的核心概念、实际应用以及设计原则设计问题&#xff0c;以全面评估候选人的理解和应用能力。以下是可能的面试问题&#xff1a; 基本概念与实现方式 请解释Java中封装、继承、多态的基本概念及其在Java中…

lxml 教程:Python 中高效处理 XML 和 HTML 的利器

一、引言 在 Python 开发中&#xff0c;经常需要处理 XML 和 HTML 数据&#xff0c;如网页数据抓取、配置文件解析等。lxml 是一个功能强大且高效的库&#xff0c;它基于 libxml2 和 libxslt 库&#xff0c;提供了简洁易用的 API 来处理 XML 和 HTML 文档。本教程将详细介绍 l…