位置: 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服务器)

  • ipad gps定位(ipad gps)(ipad定位准不准)

    ipad gps定位(ipad gps)(ipad定位准不准)

  • wps公式编辑器怎么调出来(wps公式编辑器怎么打空格)

    wps公式编辑器怎么调出来(wps公式编辑器怎么打空格)

  • OPPO Ace2可以使用两张电信卡的吗(oppo ace2使用感受)

    OPPO Ace2可以使用两张电信卡的吗(oppo ace2使用感受)

  • 荣耀10青春版华为机型叫什么(荣耀10青春版华为账号密码都忘记了怎么办)

    荣耀10青春版华为机型叫什么(荣耀10青春版华为账号密码都忘记了怎么办)

  • 显卡插主板哪里(显卡往主板哪里插)

    显卡插主板哪里(显卡往主板哪里插)

  • 运行应用程序时,需要操作系统提供哪些支持(运行应用程序时如果内存不够怎么解决)

    运行应用程序时,需要操作系统提供哪些支持(运行应用程序时如果内存不够怎么解决)

  • 苹果第一代手机名字(苹果第一代手机销量)

    苹果第一代手机名字(苹果第一代手机销量)

  • 支持7天无理由退换货是什么意思(淘宝怎样设置不支持7天无理由)

    支持7天无理由退换货是什么意思(淘宝怎样设置不支持7天无理由)

  • 微博提示音怎么设置(微博提示音怎么设置自己喜欢的)

    微博提示音怎么设置(微博提示音怎么设置自己喜欢的)

  • 华为电源键在哪里(华为手机电源键在哪里)

    华为电源键在哪里(华为手机电源键在哪里)

  • dasd都是什么类型的(dads是什么意思啊)

    dasd都是什么类型的(dads是什么意思啊)

  • 三星wqhd是2k吗(三星 hd)

    三星wqhd是2k吗(三星 hd)

  • pr为什么导入视频绿屏(pr为什么导入视频只有声音)

    pr为什么导入视频绿屏(pr为什么导入视频只有声音)

  • 荣耀20的红外遥控呢(荣耀20红外遥控在哪里设置)

    荣耀20的红外遥控呢(荣耀20红外遥控在哪里设置)

  • 华为手机怎么复制图片(华为手机怎么复制电话号码到卡上)

    华为手机怎么复制图片(华为手机怎么复制电话号码到卡上)

  • iphonex怎么反向充电(iphonex如何反向充电)

    iphonex怎么反向充电(iphonex如何反向充电)

  • 微信出行历史怎么看(微信里面出行历史)

    微信出行历史怎么看(微信里面出行历史)

  • 华为nova5i有红外线吗(华为nova5i有红外线吗可以开空调吗)

    华为nova5i有红外线吗(华为nova5i有红外线吗可以开空调吗)

  • 消息免打扰关联qq可以收到么(消息免打扰关联账号是否看得见)

    消息免打扰关联qq可以收到么(消息免打扰关联账号是否看得见)

  • 小米5黑屏无法唤醒屏幕(小米5黑屏无法重启)

    小米5黑屏无法唤醒屏幕(小米5黑屏无法重启)

  • win10下载不了软件(w10下载不了软件)

    win10下载不了软件(w10下载不了软件)

  • 抖音随拍和作品有什么区别(抖音的随拍是不是作品)

    抖音随拍和作品有什么区别(抖音的随拍是不是作品)

  • 小米手环4和4nfc版的区别(小米手环4和5外观区别)

    小米手环4和4nfc版的区别(小米手环4和5外观区别)

  • 新标记已收集怎么关(新标记已收集 空标记怎么取消)

    新标记已收集怎么关(新标记已收集 空标记怎么取消)

  • 税控盘版本号怎么看(税控盘版本低怎么升级)

    税控盘版本号怎么看(税控盘版本低怎么升级)

  • 离境退税政策文件
  • 城市维护建设税优惠政策
  • 注册商标费用计算方法
  • 固定资产盘点折旧怎么算
  • 采购商品的会计分录料未到票到
  • 无形资产一般包括专利权
  • 建筑企业外管证有效期
  • 结转成本时是否含税
  • 个人所得税离职补偿金优惠政策
  • 结算金额和付款金额
  • 运输公司支付的运输费计入什么科目
  • 特种设备电梯如何监管
  • 支付城镇土地使用税会计科目
  • 企业收到预收账款,能不能给购买方开具发票
  • 净现值为什么要除以它的折现率
  • 人身意外伤害险保障范围
  • 含有商品编码的增值税普通发票如何开具?
  • 外购低值易耗品可以抵扣进项税额吗
  • 增值税专用发票的税率是多少啊
  • 企业的哪些活动属于投资活动?
  • 企业注销后款项怎么结算
  • 营改增文化体育服务包括哪些
  • 摊销生产车间负担的保险费
  • 对公账号钱怎么拿出来
  • 管理不善造成的损失怎么处理
  • 工业厂房的辅助用房
  • 网络销售平台优势有哪些
  • 发票跨期审计调查报告
  • 鸿蒙系统通知栏和控制
  • php 7 8
  • php生成二维码
  • 艾灸的好处与功效女人
  • 重楼的功效与作用价格
  • debian更换国内源教程
  • 美丽的大中华
  • 生产车间人员招聘要求
  • php模板引擎执行时间
  • 深拷贝的实现方式
  • web前端修炼之道
  • vue elementui table
  • 事业单位政府拨款的会计分录
  • python最小正整数
  • 其他应收款专项审计报告
  • 个体户给对方公司开发票会怎样
  • 扣非净利润为什么比净利润高
  • 母子公司之间借款要交税吗
  • 工业企业出租设备租金计入什么科目
  • 工会活动个人奖励标准
  • 研发活动发生的费用
  • 税控盘退费怎么做会计分录
  • 环境检测费账务处理
  • 销售软件产品
  • 收到一张发票摘要怎么填
  • 调整期初库存商品分录
  • 交易性金融资产公允价值变动计入
  • 投资性房地产在建
  • 税收罚款支出计算公式
  • 当月计提公积金下月发放怎么做分录
  • 车船税没发票只交可以吗
  • 净现值率和现值指数与净现值什么时候它们评价结果一致
  • 物业管理企业应设置代管基金和代收款项账户
  • 数据库预处理语句
  • mysql常见报错
  • 网关dns配置异常是什么意思
  • centos6.8安装不上
  • linux中修改root密码
  • win10预览版21337
  • win8应用程序
  • 校园网升级套餐
  • iptables防火墙规则
  • 解决胃胀气最快方法
  • js中的正则表达式的例子
  • 用户dsn添加
  • chrome调试js
  • jQuery Ajax传值到Servlet出现乱码问题的解决方法
  • android开发之apritag
  • html购物网站
  • 河南省城镇土地使用税优惠政策2020
  • 普宁市离揭阳市有多远
  • 社保缴费信息提醒怎么改
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设