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

  • 快手怎么建小号(快手怎么建小号?)

    快手怎么建小号(快手怎么建小号?)

  • 华为p40pro屏幕像素密度ppi是多少呢(华为p40pro屏幕感觉不清晰)

    华为p40pro屏幕像素密度ppi是多少呢(华为p40pro屏幕感觉不清晰)

  • 小米手环支付宝付款能离开手机使用吗(小米手环支付宝的二维码和条形码区别)

    小米手环支付宝付款能离开手机使用吗(小米手环支付宝的二维码和条形码区别)

  • 华为手机虚拟按键怎么设置(华为手机虚拟按键怎么关闭)

    华为手机虚拟按键怎么设置(华为手机虚拟按键怎么关闭)

  • 怎么查看微信有没有异常(怎么查看微信有没有在电脑登录)

    怎么查看微信有没有异常(怎么查看微信有没有在电脑登录)

  • 手机用着用着就自己重启了(手机用着用着就自动关机是什么原因)

    手机用着用着就自己重启了(手机用着用着就自动关机是什么原因)

  • 键盘尺寸(苹果键盘尺寸)

    键盘尺寸(苹果键盘尺寸)

  • mov是什么格式的视频(mov是什么格式的文件怎么打开)

    mov是什么格式的视频(mov是什么格式的文件怎么打开)

  • 换显卡需要注意什么(更换显卡需要注意)

    换显卡需要注意什么(更换显卡需要注意)

  • 华为mate30有几个卡槽(华为mate30有几个版本的区别)

    华为mate30有几个卡槽(华为mate30有几个版本的区别)

  • ps2020闪退是什么原因(ps2020闪退打不开怎么办)

    ps2020闪退是什么原因(ps2020闪退打不开怎么办)

  • 机票极速出行是什么意思(飞机票极速出票)

    机票极速出行是什么意思(飞机票极速出票)

  • 手机永恒模式什么意思(啥叫永恒模式)

    手机永恒模式什么意思(啥叫永恒模式)

  • 微信电话会议最多几个人(微信会议电话如何使用)

    微信电话会议最多几个人(微信会议电话如何使用)

  • 苹果11的关机键在哪(苹果11的关机键是哪个)

    苹果11的关机键在哪(苹果11的关机键是哪个)

  • ipad晚上需要关机吗(ipad每天晚上需要关机吗)

    ipad晚上需要关机吗(ipad每天晚上需要关机吗)

  • 手机收验证码要钱吗(手机收验证码要钱吗是真的吗)

    手机收验证码要钱吗(手机收验证码要钱吗是真的吗)

  • 小米8nfc在哪打开(小米8nfc在哪里读取)

    小米8nfc在哪打开(小米8nfc在哪里读取)

  • applewatchgps和蜂窝有什么区别(apple watchgps和蜂窝)

    applewatchgps和蜂窝有什么区别(apple watchgps和蜂窝)

  • 小米9和9pro区别(小米9和小米9pro哪个性价比高)

    小米9和9pro区别(小米9和小米9pro哪个性价比高)

  • 怎么理解5g时代意味着什么意思(如何理解5g时代)

    怎么理解5g时代意味着什么意思(如何理解5g时代)

  • 废旧手机怎么处理(废旧手机怎么处理才不会泄密)

    废旧手机怎么处理(废旧手机怎么处理才不会泄密)

  • 唱吧怎么偷偷访问别人(唱吧怎么偷偷访问)

    唱吧怎么偷偷访问别人(唱吧怎么偷偷访问)

  • 易思汇怎么用(易思汇付款流程)

    易思汇怎么用(易思汇付款流程)

  • 华为watch3发布时间(华为watch3发布价)

    华为watch3发布时间(华为watch3发布价)

  • 京东快递加盟条件(京东快递加盟条件县级代理)

    京东快递加盟条件(京东快递加盟条件县级代理)

  • qq音乐如何看听歌时间(QQ音乐如何看听了多少首歌)

    qq音乐如何看听歌时间(QQ音乐如何看听了多少首歌)

  • xr壁纸不能缩放(xr壁纸不能缩放怎么回事)

    xr壁纸不能缩放(xr壁纸不能缩放怎么回事)

  • excel如何插入图表(excel中如何添加图例)

    excel如何插入图表(excel中如何添加图例)

  • SwiftUI 布局协议 - Part1(swift 协议扩展)

    SwiftUI 布局协议 - Part1(swift 协议扩展)

  • 进项税额转出补交税款
  • 税控盘是什么干嘛的
  • 利润表中的所得税费用怎么填
  • 车辆购置税可以刷信用卡吗?
  • 普通发票被作废的话财务会发现吗
  • 残保金滞纳金能抵扣吗
  • 个税的专项扣除包括哪些内容
  • 采购商品成本包括
  • 预付款核销会计分录
  • 汇算清缴的利润表本期数与本年数
  • 土地增值税税收优惠
  • 一般纳税人增值税申报操作流程
  • 来料加工与进料加工的相似之处有
  • 银行卡撤销账户
  • 会计学中营业利润的计算
  • 营改增后企业要交哪些税
  • 刷信用卡付货款怎么操作
  • 印花税工会经费会计分录
  • 航天信息的服务费
  • 出纳如何登账
  • 补缴去年地税社保的会计分录怎么写?
  • 物业公司收取公摊水电费合理吗
  • 公司亏损没有收入怎么办
  • 取得专用发票不交增值税
  • 到期一次还本付息债券
  • 营业收入在财务报表上跟实际多出来怎么解释
  • 公司筹建期间的劳务费怎么入账
  • 计提本月银行借款
  • 购买方取得专票会计分录
  • 分红个人所得税怎么交
  • 企业所得税季度申报表A类
  • 企业社保缴费工资
  • 五险二金的二金有什么好处
  • php数组函数输出《咏雪》里有多少"片"字
  • 期初留存收益是什么科目
  • wordpress.org
  • 权限控制的原则是什么
  • 销售佣金在所得税里扣吗
  • Laravel 5.4重新登录实现跳转到登录前页面的原理和方法
  • yii2超好用的日期组件和时间组件
  • 企业向个人租房子需要缴纳什么税
  • axios请求设置超时时间
  • 长期借款账务处理会计分录怎么写
  • 增值税怎么算出来的
  • 节假日加班工资是几倍
  • 公司扣个税查不到怎么办
  • 业务招待费可以结转以后年度扣除吗
  • 销售额营业收入怎么填
  • 预缴增值税款怎么入账
  • 公司向个人支付居间费用
  • 用友t3系统功能怎么用
  • 接受捐赠按什么价值入账
  • 年报资金数额是什么意思
  • 个体户开电子发票怎么申请
  • sql命令语句
  • 蓝字发票红字发票什么意思
  • 进项税额转出是借方科目还是贷方科目
  • 哪类企业是可以避税的
  • 借款怎么入会计分录
  • 一般纳税人进销不符怎么办
  • 年初余额和期末余额对不上怎么办
  • 废品相关内容有哪些
  • 固定资产报废电费怎么算
  • 长期待摊费用如何做分录
  • 如何调整以前年度错账
  • 公司的三证合一是什么
  • ubuntu18.04lts
  • linux常用基本命令pwd
  • [下载转存] 经验本题库源文件下载转存 秒结
  • win8怎么停止自动更新
  • win8桌面不显示
  • win10老是弹提示
  • style js
  • 分离与继承的思想是什么
  • shell命令是干嘛的
  • 编写shell脚本,批量建立用户
  • unity游戏开发简历
  • 使用chrome浏览器打开
  • unity控制组件开关
  • 税务部门三化建设
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设