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

  • 传统企业怎样才能玩转微博营销(传统企业怎么转型)

    传统企业怎样才能玩转微博营销(传统企业怎么转型)

  • 微信群文件在哪里(微信群文件在哪个目录)

    微信群文件在哪里(微信群文件在哪个目录)

  • 红米k40Pro长焦微距多少(红米k40pro长焦微距怎么用)

    红米k40Pro长焦微距多少(红米k40pro长焦微距怎么用)

  • 苹果xr卡屏关不了机(苹果xr卡屏不动也重启不了)

    苹果xr卡屏关不了机(苹果xr卡屏不动也重启不了)

  • jbat1是什么接口(jbd1是什么接口)

    jbat1是什么接口(jbd1是什么接口)

  • 芒果tv怎么悬浮窗(芒果tv悬浮窗在哪里)

    芒果tv怎么悬浮窗(芒果tv悬浮窗在哪里)

  • miui12支持哪些机型(miui12系统支持哪些手机)

    miui12支持哪些机型(miui12系统支持哪些手机)

  • 抖音有个剪辑视频的软件是什么(抖音中的剪辑)

    抖音有个剪辑视频的软件是什么(抖音中的剪辑)

  • 芒果tv会员最多几个人(芒果tv会员最多共享几个人登录)

    芒果tv会员最多几个人(芒果tv会员最多共享几个人登录)

  • 怎么设置手机返回键的位置(怎么设置手机返回键显示)

    怎么设置手机返回键的位置(怎么设置手机返回键显示)

  • 脚注和尾注有什么区别(脚注和尾注有什么用)

    脚注和尾注有什么区别(脚注和尾注有什么用)

  • 无线频宽是什么意思(wifi无线频宽哪个好)

    无线频宽是什么意思(wifi无线频宽哪个好)

  • 指纹锁打不开了要怎样才能打开(指纹锁打不开了怎么办解锁)

    指纹锁打不开了要怎样才能打开(指纹锁打不开了怎么办解锁)

  • 荣耀手机怎么设置时间(荣耀手机怎么设置锁屏壁纸)

    荣耀手机怎么设置时间(荣耀手机怎么设置锁屏壁纸)

  • 电脑上的ppt打不开怎么回事(电脑上的PPT打不开怎么办)

    电脑上的ppt打不开怎么回事(电脑上的PPT打不开怎么办)

  • 磁盘和光盘属于什么媒体(磁盘和光盘属于什么文献)

    磁盘和光盘属于什么媒体(磁盘和光盘属于什么文献)

  • 惠普1219用什么硒鼓(惠普打印机1219支持无线打印吗)

    惠普1219用什么硒鼓(惠普打印机1219支持无线打印吗)

  • 手机倒充电怎么回事(手机倒充电怎么恢复)

    手机倒充电怎么回事(手机倒充电怎么恢复)

  • 手机怎样可以当电视遥控器(手机怎样可以当门禁卡用)

    手机怎样可以当电视遥控器(手机怎样可以当门禁卡用)

  • python字符串替换(python字符串替换replace)

    python字符串替换(python字符串替换replace)

  • iwatch心率功能在哪(applewatch心率)

    iwatch心率功能在哪(applewatch心率)

  • 荣耀8xmax什么时候上市的(荣耀8xmax现在还值得入手吗)

    荣耀8xmax什么时候上市的(荣耀8xmax现在还值得入手吗)

  • 为什么我的朋友圈只能发10秒视频(为什么我的朋友国籍被注销)

    为什么我的朋友圈只能发10秒视频(为什么我的朋友国籍被注销)

  • xr后屏发热异常(iphonexr屏幕发烫)

    xr后屏发热异常(iphonexr屏幕发烫)

  • 小规模销售收入要做销项税额吗
  • 未取得房屋产权证租赁
  • 偶然所得个人所得税会计分录
  • 仓库盘亏怎么处理
  • 月末进项税大于销项税怎么结转
  • 招标押金如何做账务处理?
  • 小规模附加税是多少
  • 员工意外险费用
  • 机票抵进项税税率
  • 劳动保护费现金流量表项目
  • 土地出让金评估费怎么算
  • 安置残疾人就业税收优惠政策
  • 订单式生产管理
  • 基金公司的资本结构
  • 国有企业的所得税怎么算
  • 认证后的发票可以留存多久
  • 增值税专票的收款人必须是个人嘛
  • 环境保护税法什么时候出台
  • 金三系统打印控件下载及报税流程
  • 职工福利费用于职工食堂食材补助办法
  • 金蝶报告
  • 增值税税率变动情况
  • 制造企业材料返回流程图
  • 营业收入大于营业成本居然亏损
  • 企业公益捐赠的意义
  • 什么原因导致血脂高
  • win10应用商店变成英文怎么改成中文
  • fat文件系统包括
  • 施工费增值税专用发票税率
  • 进项票与实际支出金额不符
  • php 如何下载
  • win10电脑设备管理器在哪
  • 应付账款周转天数长对企业的影响
  • 垫资计入什么会计科目
  • 收到投标保证金利息如何账务处理
  • 应收未收是什么
  • 优先股转化
  • 如何认定为软件企业
  • vue表单验证数字
  • 应收票据的账务处理讲解
  • 补充养老保险税前扣除标准与扣除比例
  • 第二季度企业所得税怎么算出来
  • thinkphp隐藏index.php
  • resnet+unet
  • php微信公众号开源框架
  • 关于申请补发工资的申请
  • 微信收款计入哪个科目
  • 当月已入账可是未入账
  • 教育费附加免征额
  • phpcms是什么框架
  • 帝国cms使用手册
  • 增发股票购买子公司
  • 公司代个人缴纳社保,但不发工资和交税
  • 固定资产清理的账务处理
  • 盈余公积转增实收资本会计科目
  • 合并报表长投和股本抵消后资产负债表怎么处理
  • 在mysql中设置事务保存点
  • 别人公司过账用自己的银行卡会查吗
  • 业务往来接受礼品
  • 加计抵减不符合怎么办
  • 股息所得缴纳个税吗
  • 财务软件怎样和银行对账
  • 待认证进项发票哪里导出来数据
  • 无形资产资本化加计扣除可抵扣暂时性差异
  • 注册公司的流程及费用标准
  • 接受捐赠的固定资产计入什么科目
  • 出售二手固定资产如何开票
  • 编写sql需要注意什么
  • sql优化的一般步骤
  • sqlserver按时间查询
  • win8怎么一开机就进入桌面
  • win10系统怎么新建磁盘
  • centos 添加服务
  • linux ftp搭建教程
  • win7更改磁盘分区
  • UNITY 4.6.2 IOS 64-BIT SUPPORT
  • unity怎么创建摄像机
  • 谈谈关于中华文明的五个突出特性
  • unity unite
  • 用于赞助的消费品需要缴纳消费税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设