位置: IT常识 - 正文

rk3588使用npu进行模型转换和推理,加速AI应用落地(rk3328 sdk)

编辑:rootadmin
rk3588使用npu进行模型转换和推理,加速AI应用落地 文章目录🍉零、引言🍍一、主要功能🍎二、系统依赖🍌三、安装RKNN-Toolkit1、安装Python3.6和pip32、 安装相关依赖3、获取RKNN-Toolkit2安装包4、安装Python环境5、安装RKNN-Toolkit26、检验是否安装成功🍇四、在PC上仿真运行示例1、进入目录2、运行程序3、模型和推理结果🍉零、引言

推荐整理分享rk3588使用npu进行模型转换和推理,加速AI应用落地(rk3328 sdk),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:rk3566 sdk,rk3399pro npu开发,rk3399pro npu开发,rk3288 sdk,rk3288 isp,rk3588 npu,rk3566 npu,rk3588 npu,内容如对您有帮助,希望把文章链接给更多的朋友!

本文完成于2022-07-02 20:21:55。博主在瑞芯微RK3588的开发板上跑了deepsort跟踪算法,从IP相机中的server拉取rtsp视频流,但是fps只有1.2,和放PPT一样卡顿,无法投入实际应用。本来想使用tensorrt进行加速推理,但是前提需要cuda,rk的板子上都是Arm的手机gpu,没有Nvidia的cuda,所以这条路行不通。那么转过来,使用开发板自带的NPU进行加速推理,岂不是更加可行,而且它本身就是深度学习嵌入式板子,不用NPU真的可惜。

🏅问题来了:怎么使用NPU?在开发板上还是在自己的PC上?要安装什么环境?怎么安装?这些问题都需要依次考虑清楚。因为我在此之前也没有接触过NPU,所以为此做了很多功课,看了很多教程,总计有10h以上。然后今天自己成功实践了下转换rknn模型,并使用npu推理。为了让后面的同学少走弯路,特此花1个h记录下这个使用过程,因为官方教程真的很不详细,很多地方都需要自己踩坑然后填好,那么开始正题!

🍍一、主要功能

RKNN-Toolkit2 是为用户提供在 PC、 Rockchip NPU 平台上进行模型转换、推理和性能评估的开发套件,用户通过该工具提供的 Python 接口可以便捷地完成以下功能:

🏆模型转换:支持 Caffe、TensorFlow、TensorFlow Lite、ONNX、DarkNet、PyTorch 等模型转为 RKNN 模型,并支持 RKNN 模型导入导出,RKNN 模型能够在 Rockchip NPU 平台上加载使用。🎽量 化 功 能 : 支 持 将 浮 点 模 型 量 化 为 定 点 模 型 , 目 前 支 持 的 量 化 方 法 为 非 对 称 量 化 , 并 支 持 混 合 量 化 功 能 。asymmetric_quantized-16 目前版本暂不支持。🎯模型推理:能够在 PC 上模拟 Rockchip NPU 运行 RKNN 模型并获取推理结果;或将 RKNN模型分发到指定的 NPU 设备上进行推理并获取推理结果。🏋性能和内存评估:将 RKNN 模型分发到指定 NPU 设备上运行,以评估模型在实际设备上运行时的性能和内存占用情况。🎼量化精度分析:该功能将给出模型量化前后每一层推理结果与浮点模型推理结果的余弦距离,以便于分析量化误差是如何出现的,为提高量化模型的精度提供思路。

RK3588 内置 NPU 模块, 处理性能最高可达6TOPS。使用该NPU需要下载RKNN SDK,RKNN SDK 为带有 NPU 的RK3588S/RK3588 芯片平台提供编程接口,能够帮助用户部署使用 RKNN-Toolkit2 导出 RKNN 模型,加速 AI应用 的落地。

🍎二、系统依赖

本开发套件支持运行于 Ubuntu操作系统 (目前版本 Windows、MacOS、Debian 等暂不支持)。 Ubuntu系统需要满足以下运行环境要求:

操作系统版本Ubuntu18.04(x64)及以上Python 版本3.6 / 3.8Python 库依赖详见 doc/requirements*.txt🍌三、安装RKNN-Toolkit

下面我以 Ubuntu 18.04、Python3.6 为例,说明如何快速上手使用 RKNN-Toolkit2。我的开发板为ITX-3588J,但是开发板型号并不影响。

1、安装Python3.6和pip3sudo apt-get install python3 python3-dev python3-pip

2、 安装相关依赖sudo apt-get install zlib1g zlib1g-dev

注意这个包中间是数字1,不是字母l,直接复制命令回车最安全。

sudo apt-get install libxslt1-dev libglib2.0-0 libsm6 libgl1-mesa-glx libprotobuf-dev gcc

我的Ubuntu系统已经装了很多SLAM的环境,真的很担心依赖冲突,不过经过检验,发现并没有任何冲突。

3、获取RKNN-Toolkit2安装包

从Firefly官网获取RKNN_SDK_V1.3.0工具, 里面会有RKNN-Toolkit2 安装包,我是保存到百度网盘,然后在Windows下载好之后,使用U盘拷贝到Ubuntu系统的。当然也可以直接通过官网下载,但是比较慢。如果你是从网盘下载的,里面的docker镜像文件不需要下载,用不到,大家切记!解压后,你的文件夹内容应该和我一样(rknpu2_1.3.0是我从外面解压进来了,本教程还用不到,在后面的教程会用到)。

4、安装Python环境rk3588使用npu进行模型转换和推理,加速AI应用落地(rk3328 sdk)

之前安装的是Ubuntu依赖,这里需要安装numpy、python_opencv等依赖包。这里为了防止Python环境污染,我使用了virtualenv来管理环境,非常方便且安全,安装和使用方法可以查看这篇教程:如何安装和使用virtualenv——python环境的管理大师。这篇教程中创建的环境也就是我这里要使用的环境。

先激活环境,然后pip install -r doc/requirements_cp36-1.3.0.txt,如果出现报错:

上面在安装bfloat16时失败,因为它依赖于numpy,但是它并没有被安装呢,所以我们先手动安装下numpy。

pip install numpy==1.16.6

然后重新执行命令:pip install -r doc/requirements_cp36-1.3.0.txt,上面已经下载好的依赖不会重复下载,所有依赖下载完成后进行统一安装。

5、安装RKNN-Toolkit2sudo pip3 install packages/rknn_toolkit2-1.3.0_11912b58-cp36-cp36m-linux_x86_64.whl

可以看到在py36环境中,所有依赖都已满足。

6、检验是否安装成功python3from rknn.api import RKNN

如果导入 RKNN 模块没有失败,说明安装成功。同时按住 Ctrl+D 退出 Python3。

🍇四、在PC上仿真运行示例

RKNN-Toolkit2 自带了一个模拟器,可以用来仿真模型在 npu 上运行时的行为。就相当于Android Studio自带模拟器一样。那么真机就相当于开发板。RK3588目前只支持模拟仿真,还不支持连板调试,在真机上会报错显示rknn server版本过低,等后面官方更新好就可以连板推理了。

这里我以 yolov5 为例。examples中的yolov5是一个 onnx 模型,用于目标检测,它是在模拟器上运行的。

1、进入目录cd examples/onnx/yolov52、运行程序python3 test.py

可以看到程序中执行的主要操作有:创建 RKNN 对象;模型配置;加载 onnx 模型;构建 RKNN 模型;导出 RKNN 模型;加载图片并推理,得到推理结果;释放 RKNN 对象。

examples 目录中的其他示例的执行方式与 yolov5 相同,这些模型主要用于图像分类、目标检测。

3、模型和推理结果

简单修改下test.py文件,显示并保存结果图片,不得不说,npu推理的检测框置信度高的离谱,不愧是嵌入式神经网络,比原先yolov5高很多。而且运行速度也比官网的cpu版本快很多。

转 换 后 的 模 型 默 认 保 存 路 径 为/rknn-toolkit2-1.x.x/examples/onnx/yolov5/yolov5s.rknn ,推 理 的 图 片 结 果 保 存 在/rknn-toolkit2-1.x.x/examples/onnx/yolov5/result.jpg。

参考文献:Rockchip_Quick_Start_RKNN_Toolkit2_CN-1.3.0.pdf

本文链接地址:https://www.jiuchutong.com/zhishi/281327.html 转载请保留说明!

上一篇:dotnetfx.exe是什么进程(dotnetfx35.exe)

下一篇:Linux使用xinetd服务的管理方法案例详解(如何使用linux服务器)

  • 如何解绑银行卡绑定的微信(如何解绑银行卡绑定的支付宝)

    如何解绑银行卡绑定的微信(如何解绑银行卡绑定的支付宝)

  • qq怎样取消屏蔽(qq怎样取消屏蔽好友的消息)

    qq怎样取消屏蔽(qq怎样取消屏蔽好友的消息)

  • 京东怎么开店铺(京东怎么开店铺需要多少钱)

    京东怎么开店铺(京东怎么开店铺需要多少钱)

  • 华为荣耀10电源键坏了怎么开机(华为荣耀10电源键失去弹性)

    华为荣耀10电源键坏了怎么开机(华为荣耀10电源键失去弹性)

  • 淘宝扣分会多久清零(淘宝被扣分了多久才能销掉)

    淘宝扣分会多久清零(淘宝被扣分了多久才能销掉)

  • 微信自动扣款在哪关闭(微信自动扣款在哪里设置)

    微信自动扣款在哪关闭(微信自动扣款在哪里设置)

  • oppo手机怎么截屏 (oppo手机怎么截图 按哪里)

    oppo手机怎么截屏 (oppo手机怎么截图 按哪里)

  • 耳机皮套开裂怎么处理(耳机皮罩裂开怎么办)

    耳机皮套开裂怎么处理(耳机皮罩裂开怎么办)

  • 滴滴账号出借他人能解封么(滴滴账号出借他人怎么解封)

    滴滴账号出借他人能解封么(滴滴账号出借他人怎么解封)

  • 手机磕碰掉漆怎么修补(手机嗑掉漆)

    手机磕碰掉漆怎么修补(手机嗑掉漆)

  • kindle电池容量(kindle电池容量为什么这么低)

    kindle电池容量(kindle电池容量为什么这么低)

  • 安卓的内存总是占一半(安卓内存越来越多)

    安卓的内存总是占一半(安卓内存越来越多)

  • 腾讯会议结束后会自动退出吗(腾讯会议结束后聊天记录怎么看)

    腾讯会议结束后会自动退出吗(腾讯会议结束后聊天记录怎么看)

  • 一个企业可以认证几个抖音号(一个企业可以认证几个小红书)

    一个企业可以认证几个抖音号(一个企业可以认证几个小红书)

  • 单反相机怎么开机(单反相机怎么开始拍照)

    单反相机怎么开机(单反相机怎么开始拍照)

  • 电脑外壳划痕怎么处理(电脑外壳划痕怎么去掉)

    电脑外壳划痕怎么处理(电脑外壳划痕怎么去掉)

  • 手机壳带磁铁对手机有影响吗(手机壳带磁铁对手机信号有影响吗)

    手机壳带磁铁对手机有影响吗(手机壳带磁铁对手机信号有影响吗)

  • 电话卡为什么打不了电话(电话卡为什么打不通电话)

    电话卡为什么打不了电话(电话卡为什么打不通电话)

  • 红米k30发布时间(红米k60上市时间和价格)

    红米k30发布时间(红米k60上市时间和价格)

  • wps如何制作触发器(wps如何添加触发器动画)

    wps如何制作触发器(wps如何添加触发器动画)

  • 华为nova3外观尺寸(nova3外观尺寸)

    华为nova3外观尺寸(nova3外观尺寸)

  • 手机qq厘米秀怎么开启(手机QQ厘米秀怎么打开)

    手机qq厘米秀怎么开启(手机QQ厘米秀怎么打开)

  • 剪映教程音乐识别字幕(如何剪映音乐)

    剪映教程音乐识别字幕(如何剪映音乐)

  • 腾讯视频怎么修改青少年(腾讯视频怎么修改绑定的手机号)

    腾讯视频怎么修改青少年(腾讯视频怎么修改绑定的手机号)

  • 有骚扰电话怎么处理(骚扰电话咋办)

    有骚扰电话怎么处理(骚扰电话咋办)

  • vivox9如何备份(vivox9如何备份照片)

    vivox9如何备份(vivox9如何备份照片)

  • 爱奇艺没有字幕怎么办(爱奇艺没有字幕的电影如何把电影调出来)

    爱奇艺没有字幕怎么办(爱奇艺没有字幕的电影如何把电影调出来)

  • deepin20语音记事本在哪? deepin语音记事本的使用方法(deepin声音)

    deepin20语音记事本在哪? deepin语音记事本的使用方法(deepin声音)

  • 二分查找(二分查找和折半查找一样吗)

    二分查找(二分查找和折半查找一样吗)

  • 食堂用固定资产可以抵扣吗
  • 工资怎么扣费
  • 加了油的电子发票怎么导出来
  • 利润表的营业成本包括哪些
  • 调整上月的生产成本
  • 房地产企业成本分摊方法整理(附案例分析)
  • 公司向个人租房子怎么做账
  • 物业公司收到一年物业费开具发票后如何确认收入
  • 增值税发票如何读入金税盘
  • 小企业开发票了还能零报税吗?
  • 一般纳税人认定标准500万是什么时候开始执行
  • 增值税申报表附表一填表说明
  • 建筑工程发票抵扣有时间限制吗
  • 企业转让无形资产要交增值税吗
  • 企业间借款利息开票税目
  • 进项大于销项怎么做账
  • 分公司筹备方案
  • 其他应付款挂多少有风险
  • 加油站的成品油经营许可证过期3个月还能换证吗?
  • 生产车间发生的间接费用会计科目
  • 鸿蒙系统怎样开启5G
  • bios屏蔽接口
  • 本月暂估成本的会计分录
  • 现金日记账漏记一笔怎么办
  • 冲办公费会计分录
  • 报销差旅费怎么算
  • 股东分红缴纳个税时间
  • 贷款损失准备的作用
  • php图片拼接
  • thinkphp 模块
  • 打造出ChatGPT的,是怎样一群人?
  • 前端schema
  • javascript高阶
  • 勾选发票提交后如何
  • python socket连接后发送数据被强行终止
  • C语言中如何计算除法
  • phpcms作者名不显示怎么解决
  • 经营范围没有的项目开票了会怎么样
  • 关联企业利息费用债资比
  • 公司申请破产后员工有赔偿吗
  • 公司购买的金蝶软件属于的固定资产吗
  • 预收和预付科目一样吗
  • 跨月报销的算当月还是上个月的
  • 委托代销商品是什么科目
  • 公司水电费分摊怎么算
  • 对公账户原路退回备注怎么写
  • 长期股权投资会计实训心得
  • 公司注销应付账款要为零吗
  • 确认代销手续费怎么做账
  • 纳税人去税务局办什么
  • 递延所得税资产和负债怎么理解
  • 没有开票的收入要交增值税吗
  • 新公司怎样
  • 64位 win10系统安装绿色版mysql-5.7.16-winx64的教程
  • 打开优酷视频播放
  • win10系统预览版
  • 联想系统win8
  • 远程文件管理器
  • windows7升级到win8
  • win8磁盘分区合并
  • 微软补丁发布时间
  • win7 host文件路径
  • win7系统快速关机快捷键
  • eclipse怎么创建安卓
  • python有没有翻译库
  • error C2258: illegal pure syntax, must be '= 0'
  • 初始学历是什么意思
  • egret引擎基础入门
  • pythonista可以制作app吗
  • nodejs 导出excel
  • javaScript parseInt字符转化为数字函数使用小结
  • mvp 框架
  • 全国增值税务查询官网
  • 应付和未付的区别
  • 更改国名
  • 残疾人就业有哪些选择
  • 地方税务局部门有哪些
  • 南京地税局上班时间
  • 河北税务云办税厅官方
  • 长安cs752016款2.0手动
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设