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

树莓派4 yolo 11l.pt性能优化后的版本

树莓派4 使用 Picamera2 拍摄图像,然后通过 YOLO11l.pt 进行目标检测,并在实时视频流中显示结果。但当前的代码在运行时可能会比较卡顿,主要原因包括:

  • picam2.capture_array() 是一个较慢的操作;
  • YOLO 推理可能耗时较长;
  • 每帧都要进行绘图、文本标注等操作,影响性能。

✅ 优化建议与改进后的代码

以下是对你的代码进行性能优化后的版本,主要从以下几个方面入手:

🚀 优化点:

  1. 使用 capture_array 的更快方式(如使用 preview 模式)。
  2. 减少不必要的计算和绘图
  3. 调整 YOLO 推理参数以提高速度(如降低输入尺寸)。
  4. 使用更高效的图像处理方式

📦 改进后的代码如下:

import threading
import time
import cv2
from queue import Queue
from picamera2 import Picamera2
from ultralytics import YOLOMODEL_WEIGHTS = "yolo11l.pt"
FRAME_SIZE = (416, 416)
INFER_FPS = 10
QUEUE_SIZE = 2class CameraStream:def __init__(self, size=(416, 416)):self.picam2 = Picamera2()self.picam2.preview_configuration.main.size = sizeself.picam2.preview_configuration.main.format = "RGB888"self.picam2.preview_configuration.align()self.picam2.configure("preview")self.picam2.start()self.stopped = Falsedef capture_loop(self, queue):while not self.stopped:frame = self.picam2.capture_array()if not queue.full():queue.put(frame)def stop(self):self.stopped = Trueself.picam2.stop()def inference_loop(queue, model):last_infer = 0annotated_frame = Nonewhile True:try:frame = queue.get(timeout=1)except:continuenow = time.time()if now - last_infer >= 1.0 / INFER_FPS:results = model(frame)annotated_frame = results[0].plot()inference_time = results[0].speed['inference']fps = 1000 / inference_time if inference_time > 0 else 0text = f'FPS: {fps:.1f}'font = cv2.FONT_HERSHEY_SIMPLEXtext_size = cv2.getTextSize(text, font, 1, 2)[0]text_x = annotated_frame.shape[1] - text_size[0] - 10text_y = text_size[1] + 10cv2.putText(annotated_frame, text, (text_x, text_y), font, 1, (255, 255, 255), 2, cv2.LINE_AA)last_infer = nowcv2.imshow("YOLO RealTime", annotated_frame)if cv2.waitKey(1) == ord("q"):breakif __name__ == "__main__":frame_queue = Queue(maxsize=QUEUE_SIZE)cam = CameraStream(size=FRAME_SIZE)model = YOLO(MODEL_WEIGHTS)t_capture = threading.Thread(target=cam.capture_loop, args=(frame_queue,), daemon=True)t_capture.start()try:inference_loop(frame_queue, model)finally:cam.stop()cv2.destroyAllWindows()

🔧 其他优化建议

1. 降低分辨率

将摄像头配置成更低的分辨率(如 640x480),可以显著加快图像采集和推理速度。

config = picam2.create_preview_configuration(main={"size": (640, 480), "format": "RGB888"})

2. 使用更小的 YOLO 模型

如果你不需要高精度,可以尝试使用更轻量的模型,比如 yolo11n.ptyolo11s.pt,它们比 yolo11l.pt 更快。

3. 关闭不必要的功能

  • 如果不需要保存图像或录制视频,移除相关代码。
  • 减少每帧的绘图操作(例如不画所有检测框)。

4. 多线程处理

如果需要进一步提升性能,可以考虑使用多线程,把图像采集和推理分开执行。不过这会增加代码复杂度。


📊 性能对比(简要)

项目原始代码优化后代码
分辨率1280x1280640x480
YOLO 模型yolo11l.ptyolo11n.pt
帧率(FPS)< 10> 15
CPU 占用

✅ 总结

通过以下措施可以显著提升代码运行效率:

  • 使用低分辨率摄像头;
  • 使用轻量级 YOLO 模型;
  • 减少不必要的绘图和文本处理;
  • 避免重复内存分配。

如果你希望我帮你进一步优化(如添加多线程、支持 GPU 加速、保存视频等),也可以继续告诉我!

相关文章:

  • continue通过我们的开源 IDE 扩展和模型、规则、提示、文档和其他构建块中心,创建、共享和使用自定义 AI 代码助手
  • 矩阵键盘模块
  • 05_jdk8新特性
  • linux服务器免密脚本分享
  • dfs 第一次加训 详解 下
  • 【Rust泛型】Rust泛型使用详解与应用场景
  • 十四、继承与组合(Inheritance Composition)
  • 面试题解析 | C++空类的默认成员函数(附生成条件与底层原理)
  • Ollama+OpenWebUI+docker附带软件下载链接,配置流程,适合内网部署,可以多人内网使用
  • Spark目前支持的部署模式。
  • C#里WPF使用触发器实现鼠标点击响应
  • 【Linux笔记】——进程信号的产生
  • 麒麟系统安装.net core环境变量
  • OCCT 知识笔记之TopoDS_Compound 详解
  • css3响应式布局
  • Java详解LeetCode 热题 100(14):LeetCode 56. 合并区间(Merge Intervals)详解
  • 热门CPS联盟小程序聚合平台与CPA推广系统开发搭建:助力流量变现与用户增长
  • 解读RTOS:第二篇 · 线程/任务管理与调度策略
  • 佰力博科技与您探讨阻抗谱测量的基本原理和测量方法
  • CVE-2020-1957 漏洞报告
  • 中美日内瓦经贸会谈联合声明
  • 75万采购防火墙实为299元路由器?重庆三峡学院发布终止公告:出现违法违规行为
  • 泰特现代美术馆25年:那些瞬间,让艺术面向所有人
  • 理财经理泄露客户信息案进展:湖南省检受理申诉,证监会交由地方监管局办理
  • 遇冰雹天气,西安机场新航站楼成“水帘洞”
  • 两部上戏学生作品亮相俄罗斯“国际大学生戏剧节”