0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Orange Pi 5 Plus实测:RK3588 NPU执行AI应用的效能如何?

香橙派 2023-12-21 17:58 次阅读

OPi 5Plus的SoC为Rockchip RK3588八核(4个Cortex-A76+4个Cortex-A55)架构的64位处理器,主频达 2.4GHz并带有Mali-G610 GPU,除此之外的亮点还包括了一个 6 TOPS算力的NPU,支持TensorFlow、PyTorch等常见框架转换,使其能够作为处理AI影像的边缘装置。开发板上的周边也相当丰富,包含2 Ports 2.5Gb Ethernet、3 Ports HDMI (2out + 1in)、5 Ports USB、M.2 E-Key等高速接口硬件数据看来相较树莓派而言可说是全面性的碾压,那么实际使用如何,一起往下看看!

wKgZomWEC_yAQFbhAAwg6ou3CQM235.png

怎么玩?

OPi 5 Plus支持多种操作系统,包含 Ubuntu、Debian、Android与官方自研的 Orange Pi OS等, 各位可以自行挑选喜欢的image映像下载后烧录到SD Card启动。笔者这里选择兼容性较好的Ubuntu,同时得利于Open Source的优势,安装的是非官方的Ubuntu 22.04社群版本。烧录完SD Card放入OPi 5 Plus再接上荧幕键盘网络线等,上电后后经过初始化设定即可以看到GNOME的桌面界面以及那只可爱的幸运水母。

就如同树莓派一样,当操作系统安装完成后就能够当作一般个人计算机使用,或是作为多媒体应用,甚至是搭载到移动载具上都行。由于使用的是 Ubuntu系统,软件套件支持性也相当丰富。笔者实际使用 Chromium浏览器开启YouTube 4K串流进行测试,顺畅度可以说是明显比树莓派好上许多,也没有任何影格丢失(frame drop)的现象!

神经网络运算单元 NPU

凭借着 RK3588处理器的强大效能,若使用OPi 5 Plus只是做 CPU运算就稍微可惜了,笔者本篇的最主要目的就是要体验Rockchip的NPU执行AI应用的效能如何。官方在 github上有提供对应RK3588 NPU的Library与范例程序rknpu2, 可以直接在OPi 5 Plus安装并呼叫 NPU执行,以下记录安装过程供各位参考。由于范例程序为C++语言需要进行编译,先执行系统更新并安装必要套件:

wKgaomWEC_aAW-LzAAAPs3xup5Y870.png

从 GitHub下载Repo:

wKgaomWEC_aAJYgXAAANG1xRzFM562.png

范例程序包含 API的使用与mobilenet及YOLOv5,选择YOLOv5范例进行编译:

wKgZomWEC_aAWKpxAAAPz1shSFs445.png

执行范例,带入官方预训练的 YOLOv5模型档 “yolov5s-640-640.rknn” 与推论图片 “bus.jpg”:

wKgZomWEC_aAX6DeAAAScJKovbI314.png

完成后会产生输出档案 “out.jpg”,开启后看到如下图示,主要物件接有被侦测并标记出来:

wKgaomWEC_uAWqcuAAKBJSMQJXg431.png

(OPi5Plus执行 YOLOv5图片推论结果)

若是第一次执行系统可能没有安装 RKNN的runtime library,会出现找不到.so动态连结Library导致执行失败,可以将此档案库提供的library复制到系统路径:

wKgZomWEC_eAQfyhAAAILJL_Smw523.png

YOLOv5实时影像推论

官方的范例并没有提供从 Webcam撷取影像进行推论的范例,但大家可以参考社群上这一篇教学的内容进行实作。准备好一个 UVC Webcam插上OPi 5 Plus的 USB孔,输入指令安装openCV相依套件:

wKgaomWEC_eASA9DAAAONU2Y3EM125.png

移动到 rknpu2 YOLOv5范例的路径:

wKgaomWEC_eACXNVAAANsWaMlOA984.png

下载社群 Maker提供的CMakeList.txt并复制到此目录下;下载社群Maker提供的main.cc并复制到src目录下。再次编译程序码:

wKgZomWEC_eAa6SjAAAJZGdulOY976.png

完成后动到安装路径执行范例程序,输入下方指令执行。指令带入第三个参数 “2” 代表使用/dev/Video2的装置,“1280” 代表影像的宽度,“720” 则代表影像的高度,可以依各位实际的情况调整。

wKgaomWEC_iAewwQAAAdHAwMO8s830.pngwKgaomWEC_uAErYxAAtHmNT7Pc0937.png

实际测试的结果在 1280×720 HD影像下的推论有10 FPS,若是将分辨率改为640×480则可以达到接近20 FPS。但从log看来执行推论的过程约只耗费20ms左右,其余的时间则是耗费在影像的处理与显示上了,效能可说是相当不赖。

模型转换工具 RKNN-Toolkit2

上述的推论范例使用官方预训练的 RKNN模型档,若是想要自行将不同框架的模型转成RKNN在OPi 5 Plus上推论,就必须透过官方提供的 RKNN-Toolkit2这个工具。此工具必须要在x86的PC上执行,作业系统要求为Ubuntu 18.04以上,Python 3.6以上,笔者的测试环境为Ubuntu 22.04,Python 3.10。 第一步也是要安装必要套件:

wKgZomWEC_iAdwkUAAAw5s8eVNs812.png

建立 python虚拟环境:

wKgaomWEC_iAYmayAAATdrawFjQ277.png

下载 RKNN-toolkit2:

wKgZomWEC_iAc-j9AAAZH2pXrXk329.png

安装相依套件:

wKgaomWEC_mAIl9fAAAN77_0k7s390.png

安装 RKNN-Toolkit2 Python模块:

wKgZomWEC_mAU3Z9AAAU6aKbkVI374.png

至此套件已安装完成,在此 toolkit中也有提供一些范例来转换pytorch、TensorFlow、Caffe、ONNX等不同框架的模型,可以进入到各范例中执行模型转换,举例而言要执行TensrFlow的转换范例可以输入以下指令:

wKgZomWEC_mAQEMmAAAS-Frfx0A908.png

这个指令会把目录下的 “ssd_mobilenet_v1_coco_2017_11_17.pb”TensorFlow预训练模型转换成NPU可执行的模型 “ssd_mobilenet_v1_coco.rknn”,并且会读取目录中的 “road.bmp” 档案进行推论测试。完成后即可把RKNN模型传送到Rockchip的单板计算机上执行了。

wKgZomWEC_uACw3DAASMJTS8o_A184.png

OPi 5 Plus执行 Teachable Machine转换后的RKNN模型

除了 RKNN Toolkit2内建的范例外,笔者也成功地把Teachable Machine汇出的TF.lite模型转换为RKNN模型并且在OPi 5 Plus上执行。简易流程如下:

·在 Teachable Machine训练模型,并汇出为TF.lite未量化格式

·将TF.lite模型传送到执行RKNN-toolkit2的Ubuntu PC。路径为 “rknn-toolkit2/examples/tflite/mobilenet_v1/”

·修改 “test.py” 档案,在呼叫 “rknn.config”API增加指定traget_platfrom为”rk3588”,并修改 “rknn_load_rflite”API所指定的model名称为刚刚传入的文件名称,如下图:

wKgaomWEC_qASd6IAAG6xsXgQsI756.png

·执行 python3 test.py转换模型,笔者也同时将test.py测试推论的图档改为训练资料图档,输出结果如下图,可以明确分类出图像。

wKgaomWEC_uASPHKAAdWWjNeRzk982.png

·将 rknn档案复制起来,并传送到OPi 5 Plus

·执行OPi 5 Plus的推论测试,结果如下图,可以正确的分类图片。

wKgZomWEC_qAfHtYAAKUlKdgn5U811.png

如此一来可以轻松地将 Teachable Machine客制化训练的模型放到OPi 5 Plus上执行了!

小结——展望未来想象空间更大

整体而言,Orange Pi 5 Plus适合作为智慧机上盒、智慧显示、NVR等相关应用,具备双GbE网口与多路影像输出输入是其特色。除此之外Rockchip的产品线近期已陆续搭载了NPU,让对应的单板计算机更具备竞争力,除了 CPU核心效能本身就还不错之外,还足以处理轻度物件侦测与影像分类等AI应用。唯独在 NPU工具的使用上还是稍微卡手了一些,Python文件说明也未齐全,这将直接影响Maker玩家投入开发的意愿程度。未来若能提供更人性化、更合宜的NPU开发者工具,再加上处理器本身的优异性能,可能将对边缘运算的市场造成一股破坏性的浪潮。

(以上素材来源于Felix)

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Orange
    +关注

    关注

    0

    文章

    82

    浏览量

    19624
  • 开发板
    +关注

    关注

    25

    文章

    4874

    浏览量

    96974
  • NPU
    NPU
    +关注

    关注

    2

    文章

    255

    浏览量

    18499
  • RK3588
    +关注

    关注

    6

    文章

    298

    浏览量

    4115
收藏 人收藏

    评论

    相关推荐

    RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测

    : NPU帮助机器完成更高效的翻译、文本分类和情感分析,推动了自然语言处理技术的发展。 实例分享:Yolov5分类检测 在RK3588处理器上,不仅可以基于Linux系统使用NPU,也
    发表于 10-24 10:13

    迅为瑞芯微RK3588开发板深度剖析丨首选的性能

    编码+8K解码,能够同时处理多路视频流,确保每一帧画面都流畅如丝,细腻入微。 ■ 智驭未来的AI力量 RK3588内置了6Tops(即每秒处理6万亿次操作)算力的高性能神经网络处理器单元(NPU
    发表于 10-17 10:49

    探索巅峰性能 |迅为瑞芯微RK3588开发板/核心板深度剖析

    编码+8K解码,能够同时处理多路视频流,确保每一帧画面都流畅如丝,细腻入微。 ■ 智驭未来的AI力量 RK3588内置了6Tops(即每秒处理6万亿次操作)算力的高性能神经网络处理器单元(NPU
    发表于 09-25 11:15

    迅为瑞芯微RK35883588S如何选型硬件区别

    RK3588S和RK3588处理器在接口上可是有着不小的区别哦!这两款处理器,都是市场上的热门选择,但它们的接口设计却各有千秋。 首先,我们来看看iTOP-3588开发板采用瑞芯微RK3588
    发表于 09-11 11:31

    迅为RK3588开发板深度剖析丨首选的性能

    编码+8K解码,能够同时处理多路视频流,确保每一帧画面都流畅如丝,细腻入微。 ■ 智驭未来的AI力量 RK3588内置了6Tops(即每秒处理6万亿次操作)算力的高性能神经网络处理器单元(NPU
    发表于 09-03 15:49

    RK3588!黑神话悟空,启动?-迅为电子RK3588开发板

    RK3588!黑神话悟空,启动?-迅为电子RK3588开发板
    的头像 发表于 08-30 14:13 438次阅读
    <b class='flag-5'>RK3588</b>!黑神话悟空,启动?-迅为电子<b class='flag-5'>RK3588</b>开发板

    RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测-迅为电子

    RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测-迅为电子
    的头像 发表于 08-23 14:58 520次阅读
    <b class='flag-5'>RK3588</b> 技术分享 | 在Android系统中使用<b class='flag-5'>NPU</b>实现Yolov<b class='flag-5'>5</b>分类检测-迅为电子

    RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测

    : NPU帮助机器完成更高效的翻译、文本分类和情感分析,推动了自然语言处理技术的发展。 实例分享:Yolov5分类检测 在RK3588处理器上,不仅可以基于Linux系统使用NPU,也
    发表于 08-20 11:13

    基于迅为RK3588开发板的AI图像识别方案

    源源不断的动力。 ■ 无与伦比的视觉盛宴最高支持8K编码+8K解码,能够同时处理多路视频流,确保每一帧画面都流畅如丝,细腻入微。 ■ 智驭未来的AI力量RK3588内置了6Tops(即每秒处理6万亿次
    发表于 08-13 11:26

    探索巅峰性能 |迅为 RK3588开发板深度剖析

    编码+8K解码,能够同时处理多路视频流,确保每一帧画面都流畅如丝,细腻入微。 ■ 智驭未来的AI力量 RK3588内置了6Tops(即每秒处理6万亿次操作)算力的高性能神经网络处理器单元(NPU
    发表于 08-09 15:44

    基于RK3588NPU案例分享!6T是真的强!

    本帖最后由 Tronlong创龙科技 于 2024-7-19 16:53 编辑 RK3588 NPU简介:作为瑞芯微新一代旗舰工业处理器,RK3588 NPU性能可谓十分强大,
    发表于 07-17 10:55

    实测分享,瑞芯微RK3588八核国产处理器性能测评!确实“遥遥领先”!

    实测数据 图5 RK3568处理器GPU运算性能实测数据 图6 RK3588RK356
    发表于 07-17 10:49

    迅为电子RK3588S与RK3588硬件性能区别及板卡选型

    迅为电子RK3588S与RK3588硬件性能区别及板卡选型
    的头像 发表于 06-25 15:30 2778次阅读
    迅为电子<b class='flag-5'>RK3588</b>S与<b class='flag-5'>RK3588</b>硬件性能区别及板卡选型

    香橙派推出新款开发板:瑞芯微RK3588S SoC配Orange Pi 5 Pro

    4 月 2 日,香橙派发布了新增款式的 Orange Pi 5 Pro,该新品继承了原先 Orange Pi
    的头像 发表于 04-02 09:57 892次阅读

    基于RK3588NPU案例分享!6T是真的强!

    RK3588 NPU简 介 作为瑞芯微新一代旗舰工业处理器,RK3588 NPU性能可谓十分强大,6TOPS设计能够实现高效的神经网络推理计算。这使得
    的头像 发表于 02-27 14:14 1558次阅读
    基于<b class='flag-5'>RK3588</b>的<b class='flag-5'>NPU</b>案例分享!6T是真的强!