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

从零开始:在RK3588上运行RKNN版YOLOv5目标检测(保姆级教程)

从零开始在RK3588上运行RKNN版YOLOv5目标检测保姆级教程RK3588作为Rockchip新一代旗舰级SoC其内置的NPU模块为边缘计算场景提供了强大的AI推理能力。本教程将手把手带您完成YOLOv5目标检测模型在RK3588开发板上的完整部署流程涵盖环境配置、交叉编译、模型部署等关键环节特别针对实际开发中容易遇到的ADB连接、文件传输等问题提供解决方案。1. 开发环境搭建1.1 硬件准备清单RK3588开发板建议使用官方Demo板或Firefly系列开发板Linux主机推荐Ubuntu 18.04/20.04 LTS系统连接设备USB Type-C数据线用于ADB调试网线可选用于网络传输HDMI线用于显示输出1.2 基础软件环境配置首先在Linux主机上安装必要的开发工具sudo apt update sudo apt install -y git adb sshpass验证ADB连接状态adb devices注意若设备未识别需检查开发板的USB调试模式是否开启2. RKNN工具链部署2.1 获取RKNPU2开发套件git clone --depth1 https://github.com/rockchip-linux/rknpu2.git cd rknpu22.2 安装交叉编译工具链针对RK3588的aarch64架构需要安装特定版本的交叉编译器sudo apt install gcc-9-aarch64-linux-gnu g-9-aarch64-linux-gnu验证编译器版本aarch64-linux-gnu-gcc-9 --version3. YOLOv5 Demo编译3.1 准备编译环境进入YOLOv5示例目录cd examples/rknn_yolov5_demo修改编译脚本build-linux_RK3588.sh关键参数export TOOL_CHAIN/usr/bin/aarch64-linux-gnu- export CC${GCC_COMPILER}-gcc-9 export CXX${GCC_COMPILER}-g-93.2 执行交叉编译./build-linux_RK3588.sh成功编译后会在install/rknn_yolov5_demo_Linux目录生成以下文件rknn_yolov5_demo可执行文件librknnrt.soRKNN运行时库yolov5s-640-640.rknn预编译模型4. 开发板部署实战4.1 开发板目录准备通过ADB连接开发板并创建运行目录adb shell mkdir -p /data/rknn_yolov54.2 文件传输关键步骤使用ADB推送编译产物到开发板adb push install/rknn_yolov5_demo_Linux/rknn_yolov5_demo /data/rknn_yolov5/ adb push install/rknn_yolov5_demo_Linux/model/RK3588/yolov5s-640-640.rknn /data/rknn_yolov5/ adb push install/rknn_yolov5_demo_Linux/model/coco_80_labels_list.txt /data/rknn_yolov5/ adb push install/rknn_yolov5_demo_Linux/model/bus.jpg /data/rknn_yolov5/传输进度检查技巧adb shell ls -lh /data/rknn_yolov55. 模型运行与性能测试5.1 执行目标检测在开发板终端运行cd /data/rknn_yolov5 ./rknn_yolov5_demo yolov5s-640-640.rknn bus.jpg典型输出解析person (114 235 212 527) 0.819099 # 检测到行人置信度81.9% bus (99 141 557 445) 0.693320 # 检测到公交车置信度69.3% average run 34.551800 ms # 平均推理耗时34.55ms5.2 性能优化建议优化方向具体措施预期效果提升模型量化使用INT8量化替代FP322-3倍速度提升输入分辨率调整根据场景需求降低输入尺寸减少计算量多线程推理启用RKNN的异步推理接口提高吞吐量6. 常见问题排查6.1 ADB连接失败解决方案现象adb devices显示空列表排查步骤检查开发板USB调试模式重新插拔USB线缆重启ADB服务adb kill-server adb start-server6.2 模型运行报错处理当出现Load RKNN model failed错误时确认模型路径是否正确检查librknnrt.so版本是否匹配验证模型是否针对RK3588平台编译7. 进阶开发指南7.1 自定义模型部署将PyTorch版YOLOv5模型导出为ONNX格式使用RKNN-Toolkit2进行模型转换from rknn.api import RKNN rknn RKNN() rknn.config(target_platformrk3588) rknn.load_onnx(modelyolov5s.onnx) rknn.build(do_quantizationTrue) rknn.export_rknn(yolov5s.rknn)7.2 实时摄像头推理修改Demo代码实现USB摄像头采集cv::VideoCapture cap(0); while(true) { cap frame; // 执行推理 inference(frame); }实际部署中发现RK3588的NPU在640x640分辨率下可以稳定达到30FPS以上的处理性能完全满足实时检测需求。建议首次运行时先使用静态图片验证流程再逐步过渡到视频流处理

相关文章:

从零开始:在RK3588上运行RKNN版YOLOv5目标检测(保姆级教程)

从零开始:在RK3588上运行RKNN版YOLOv5目标检测(保姆级教程) RK3588作为Rockchip新一代旗舰级SoC,其内置的NPU模块为边缘计算场景提供了强大的AI推理能力。本教程将手把手带您完成YOLOv5目标检测模型在RK3588开发板上的完整部署流程…...

显示器EDID数据解析全攻略:从制造商ID到色彩特性的秘密

显示器EDID数据解析全攻略:从制造商ID到色彩特性的秘密 当你连接一台新显示器时,操作系统是如何知道它的最佳分辨率和刷新率的?答案就藏在EDID(Extended Display Identification Data)这个小小的数据块中。EDID是显示器…...

ESP32伺服与PWM控制库:硬件自适应资源管理

1. 项目概述ESP32ServoController 是一款专为 ESP32 系列微控制器设计的高性能 PWM 与伺服控制库。它并非对 Espressif 官方 LEDC(LED Control)外设驱动的简单封装,而是基于其硬件架构进行深度抽象与工程化重构的底层控制框架。该库的核心设计…...

双Token无感刷新:从登录到重试的完整链路解析

1. 双Token机制的核心原理 想象一下你住在一个高档小区,门禁卡就是你的通行证。普通门禁卡(Access Token)有效期只有30分钟,而物业还给你一张备用卡(Refresh Token)有效期长达7天。当普通卡过期时&#xff…...

2025届必备的五大AI辅助写作工具解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前,在学术论文以及职场报告等这些内容生产场景当中,对于文本原创性…...

一道KMP统考真题彻底讲透:nextval与滑动距离的本质我

一、各自优势和对比 这是检索出来的数据,据说是根据第三方评测与企业数据,三款产品在代码生成质量上各有侧重: 产品 语言优势 场景亮点 核心差异 百度 Comate C核心代码质量第一;Python首生成率达92.3% SQL生成准确率提升35%&…...

零基础玩转OpenClaw:Qwen2.5-VL-7B多模态模型入门指南

零基础玩转OpenClaw:Qwen2.5-VL-7B多模态模型入门指南 1. 为什么选择OpenClawQwen2.5-VL组合 去年夏天,当我第一次看到同事用自然语言指令让AI自动整理会议纪要时,内心受到了巨大冲击。经过两周的折腾,我终于在自己的MacBook上搭…...

YOLO11 改进 - 特征融合 | MSAA多尺度注意力聚合模块, 多尺度卷积融合与双通道注意力机制

前言 本文介绍了将多尺度注意力聚合(MSAA)模块与YOLO11结合的方法。MSAA是CM - UNet中用于优化编码器特征、强化跳跃连接的核心模块,能解决遥感图像物体尺度差异大、多尺度特征融合弱的问题。它采用空间与通道双分支并行处理,先对输入的相邻三层特征进行拼接,再分别进行空…...

YOLO26改进 - 注意力机制 | EMA (Efficient Multi-Scale Attention) 高效多尺度注意力:跨空间学习与多分支协同增强特征表征,优化多尺度目标检测

前言 本文介绍了高效多尺度注意力(EMA)模块及其在YOLO26中的结合应用。现有注意力机制在通道维度缩减时可能影响深度视觉表示,EMA模块通过结合通道和空间信息、采用多尺度并行子网络结构等创新点,实现了高效的多尺度注意力机制。其基本原理包括通道和空间注意力结合、多尺…...

嵌入式舵机精确控制:基于硬件定时器的PWM脉宽稳定实现

1. Servo库技术解析:面向嵌入式系统的单路舵机精确控制实现1.1 库定位与工程价值Servo库是一个轻量级、面向资源受限嵌入式平台的单路舵机控制库。其核心设计哲学并非追求功能堆砌,而是聚焦于时间精度、脉宽稳定性与硬件抽象解耦三大关键指标。在STM32F0…...

职场人AI生存指南:10个核心技能,让你不被AI淘汰反而被赋能

掌握AI工具的基础应用职场人需要熟悉主流AI工具的操作,如ChatGPT、Copilot、Notion AI等。了解这些工具的基本功能,如文本生成、数据分析、自动化流程等,能够提升工作效率。定期关注AI工具的更新,学习新功能的应用场景。培养数据思…...

打工人必备!8个AI办公神器,每天准时下班不是梦

文档处理工具Notion AI 集成在Notion中的AI功能,支持自动生成文档大纲、会议纪要整理、多语言翻译。通过自然语言输入需求,快速输出结构化内容,适合项目管理与知识库搭建。ChatPDF 上传PDF文件后可直接对话式提问,提取关键信息或总…...

从PyTorch到FPGA:手把手教你将MobileNetV2模型部署到Zynq平台(附完整代码)

从PyTorch到FPGA:手把手教你将MobileNetV2模型部署到Zynq平台(附完整代码) 在边缘计算领域,FPGA因其低延迟、高能效和可重构特性,正成为轻量级CNN模型部署的理想选择。本文将带您完成一个从PyTorch模型训练到Xilinx Zy…...

嵌入式C语言设计模式实践:观察者与责任链模式

1. 嵌入式软件开发中的设计模式应用背景在传统认知中,嵌入式系统开发往往与"资源受限"、"底层硬件"、"效率优先"等标签紧密关联。早期的嵌入式设备功能单一,业务逻辑简单,开发者更关注代码的执行效率和硬件资源…...

STM32duino双VL6180X ToF传感器驱动库深度解析

1. 项目概述STM32duino X-NUCLEO-6180XA1 是一个面向 Arduino 兼容生态(特别是基于 STM32 的开发板,如 NUCLEO-F401RE、NUCLEO-F411RE、NUCLEO-L476RG 等)的硬件抽象库,专为驱动意法半导体(STMicroelectronics&#xf…...

【渗透工具】Venom多级代理实战:从零构建内网渗透通道

1. Venom工具入门:多级代理的核心价值 第一次接触Venom是在去年的一次内网渗透项目中。当时客户的内网结构复杂,常规代理工具难以穿透多层网络,直到同事推荐了这个用Go语言开发的神器。简单来说,Venom就像个数字隧道挖掘机&#x…...

嵌入式裸机开发中的轻量级定时调度方案

1. SmartTimer:裸机环境下的轻量级定时调度方案在嵌入式开发中,定时任务管理是个永恒的话题。我最近在做一个空气质量监测项目时,发现传统的裸机编程方式在处理多个定时任务时显得力不从心。硬件定时器资源有限,软件标志位管理又容…...

6000万吨产能承压 卫星化学迎来战略窗口期

据新华社报道,伊朗法尔斯通讯社7日凌晨援引未具名消息源报道,沙特阿拉伯东北部朱拜勒工业区当天发生爆炸,系遭到大范围打击。据悉,朱拜勒工业区是全球重要石化生产基地之一,年产量约6000万吨石化产品,占全球…...

10个经典C语言开源项目深度解析

1. 精选C语言开源项目解析作为一名在系统级编程领域摸爬滚打多年的开发者,我深知优秀的C语言项目对技术成长的帮助。今天要分享的这10个项目,每个都是经过时间检验的经典之作,代码量控制在3万行以内,特别适合作为学习范本。这些项…...

2026届必备的十大AI科研网站解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能技术的迅猛发展,AI论文工具已然成为学术写作范畴的关键辅助方式&…...

2025最权威的六大AI论文神器实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 关于论文一键生成的技术,它借助了先进的自动化算法,还有自然语言处理…...

用好AI的五个习惯

五个习惯一、善于拆解问题核心逻辑:AI是执行者,人是设计者。对项目的全流程和细节了如指掌,能够将复杂的大问题拆解为具体的、AI可执行的子任务。二、上下文管理大师核心逻辑:理解模型极限,追求高效输出。当前AI模型&a…...

STM32 GPIO工作模式详解与应用指南

1. STM32 GPIO工作模式深度解析作为一名嵌入式开发工程师,我经常需要与STM32的GPIO打交道。GPIO(General Purpose Input/Output)作为单片机最基础也最常用的外设,其工作模式的选择直接影响着系统稳定性和功能实现。今天我将结合自…...

MultiSerial:单UART多通道串行通信复用库

1. 项目概述MultiSerial 是一个面向嵌入式系统的多字节串行通信抽象库,其核心设计目标是在单个物理串口(UART/USART)上安全、可靠地复用多个逻辑通信通道,实现“一串口多路数据流”的工程需求。该库不依赖特定硬件平台或RTOS&…...

新质生产力水平测算(版本3,2010-2023年)

1、搜数据皮皮侠,编号14172、使用兑换码0447220m6ZHB006826sU14Vv数据来源《中国统计年鉴》、《中国能源统计年鉴》、《中国工业统计年鉴》、《中国环境统计年鉴》、能源统计局、省级统计年鉴。时间跨度2010-2023年区域跨度全国31个省市自治区(不含港澳台…...

RWA抵押:稳定币的“硬锚革命”如何撬动十万亿级金融新基建?

——波士顿咨询预言:当国债、房产上链,加密货币将迎来“信用时代”引言:稳定币的“信任危机”与RWA的破局之道2022年,LUNA/UST崩盘事件让全球加密市场陷入恐慌,算法稳定币的“无锚风险”暴露无遗。这场危机揭示了一个核…...

嵌入式系统中nanopb序列化方案的优势与实践

1. 嵌入式通信序列化的痛点与选择在资源受限的嵌入式系统中,数据序列化方案的选择往往面临多重挑战。我曾在一个智能农业传感器项目中,就遇到过这样的困境:节点设备使用STM32F103(64KB Flash,20KB RAM)&…...

高压输电线路智能监测系统设计与实现

1. 项目背景与需求分析高压输电线路作为电力系统的"大动脉",其稳定运行直接关系到整个电网的安全。我在电力行业工作多年,亲眼见过多次因间隔棒故障导致的线路跳闸事故。传统的人工巡检方式存在明显短板:巡检周期长(通常…...

Linux内核架构解析与学习路线指南

1. Linux内核概述与核心概念Linux内核作为操作系统的核心组件,负责管理系统资源、硬件抽象和进程调度等基础功能。它诞生于1991年,由Linus Torvalds开发,现已发展成为支持从嵌入式设备到超级计算机的全场景操作系统内核。提示:Lin…...

SpringAI工具调用实战:手把手教你用ChatClient集成天气查询API(附完整代码)

SpringAI工具调用实战:手把手教你用ChatClient集成天气查询API 最近在开发一个智能聊天机器人时,遇到了一个常见需求:让机器人能够回答用户关于天气的实时查询。经过一番探索,我发现SpringAI的ChatClient配合工具调用功能&#xf…...