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

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

3天内不再提示

CMSIS-NN内核的神经网络提升微控制器的性能

电子设计 作者:电子设计 2018-09-21 07:31 次阅读

目前,在许多需要在本地进行数据分析的“永远在线”的物联网边缘设备中,神经网络正在变得越来越普及,主要是因为可以有效地同时减少数据传输导致的延时和功耗。 而谈到针对物联网边缘设备上的神经网络,我们自然会想到Arm Cortex-M系列处理器内核,那么如果您想要强化它的性能并且减少内存消耗,CMSIS-NN就是您最好的选择。基于CMSIS-NN内核的神经网络推理运算,对于运行时间/吞吐量将会有4.6X的提升,而对于能效将有4.9X的提升。

CMSIS-NN库包含两个部分: NNFunction和NNSupportFunctions。 NNFunction包含实现通常神经网络层类型的函数,比如卷积(convolution),深度可分离卷积(depthwise separable convolution),全连接(即内积inner-product), 池化(pooling)和激活(activation)这些函数被应用程序代码用来实现神经网络推理应用。 内核API也保持简单,因此可以轻松地重定向到任何机器学习框架。NNSupport函数包括不同的实用函数,如NNFunctions中使用的数据转换和激活功能表。 这些实用函数也可以被应用代码用来构造更复杂的NN模块,例如, 长期短时记忆(LSTM)或门控循环单元(GRU)。

对于某些内核(例如全连接和卷积),会使用到不同版本的内核函数。 我们提供了一个基本的版本,可以为任何图层参数“按原样”通用。 我们还部署了其他版本,包括进一步的优化技术,但会对输入进行转换或对层参数有一些限制。 理想情况下,可以使用简单的脚本来分析网络拓扑,并自动确定要使用的相应函数。

我们在卷积神经网络(CNN)上测试了CMSIS-NN内核,在CIFAR-10数据集上进行训练,包括60,000个32x32彩色图像,分为10个输出类。 网络拓扑结构基于Caffe中提供的内置示例,具有三个卷积层和一个完全连接层。 下表显示了使用CMSIS-NN内核的层参数和详细运行时结果。 测试在运行频率为216 MHz的ARM Cortex-M7内核STMichelectronics NUCLEO-F746ZG mbed开发板上进行。

整个图像分类每张图像大约需要99.1毫秒(相当于每秒10.1张图像)。 运行此网络的CPU的计算吞吐量约为每秒249 MOps。 预量化的网络在CIFAR-10测试集上达到了80.3%的精度。 在ARM Cortex-M7内核上运行的8位量化网络达到了79.9%的精度。 使用CMSIS-NN内核的最大内存占用空间为〜133 KB,其中使用局部im2col来实现卷积以节省内存,然后进行矩阵乘法。 没有使用局部im2col的内存占用将是〜332 KB,这样的话神经网络将无法在板上运行。

为了量化CMSIS-NN内核相对于现有解决方案的好处,我们还使用一维卷积函数(来自CMSIS-DSP的arm_conv),类似Caffe的pooling和ReLU来实现了一个基准版本。 对于CNN应用,下表总结了基准函数和CMSIS-NN内核的比较结果。 CMSIS-NN内核的运行时间/吞吐量比基准函数提高2.6至5.4倍。 能效提高也与吞吐量的提高相一致。

高效的NN内核是充分发挥ARM Cortex-M CPU能力的关键。 CMSIS-NN提供了优化的函数来加速关键的NN层,如卷积,池化和激活。 此外,非常关键的是CMSIS-NN还有助于减少对于内存有限的微控制器而言至关重要的内存占用。 更多细节在我们的白皮书中您可以读到,您可以使用下面的按钮从康奈尔大学图书馆网站下载

CMSIS-NN内核可在上找到。 应用 代码可以直接使用这些内核来实现Arm Cortex-M CPU上的神经网络算法。 或者,这些内核可以被机器学习框架用作原语函数(primitives)来部署训练过的模型。

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

    关注

    48

    文章

    7572

    浏览量

    151636
  • 神经网络
    +关注

    关注

    42

    文章

    4774

    浏览量

    100900
  • 物联网
    +关注

    关注

    2910

    文章

    44778

    浏览量

    374664
收藏 人收藏

    评论

    相关推荐

    发布MCU上跑的轻量神经网络包 NNoM, 让MCU也神经一把

    Spotting)使用运动传感器识别活动状态 (Human Activity Recognition)神经网络控制系统 (替代PID等传统控制方法)图像处理 (带专用加速的 MCU
    发表于 05-01 19:03

    CMSIS-NN神经网络内核助力微控制器效率提升

    自然会想到Arm Cortex-M系列处理内核,那么如果您想要强化它的性能并且减少内存消耗,CMSIS-NN就是您最好的选择。基于CMSIS-NN
    发表于 07-23 08:08

    如何利用SoPC实现神经网络速度控制器

    不确定因素影响,并且随着可编程片上系统SoPC和大规模现场可编程门阵列FPGA的出现,为神经网络控制器的硬件实现提供了新的载体。
    发表于 08-12 06:25

    CMSIS-NN神经网络内核可以让微控制器效率提升5倍是真的吗?

    全新CMSIS-NN神经网络内核微控制器效率提升5倍
    发表于 03-15 06:55

    可分离卷积神经网络在 Cortex-M 处理上实现关键词识别

    更胜一筹。关键词识别神经网络管道由于要保持“永远在线”,KWS 应用的功耗预算受到很大限制。虽然 KWS 应用也可在专用 DSP 或高性能 CPU 上运行,但更适合在 Arm Cortex-M 微控制器
    发表于 07-26 09:46

    DSP数字信号处理和CMSIS-NN神经网络教程

    之后,开启第2版DSP数字信号处理和CMSIS-NN神经网络教程,同步开启三代示波器。软件:1、开发板预装出厂程序,各种外设驱动包全做好了,可以检测全部硬件功能...
    发表于 08-04 06:59

    基于BP神经网络的PID控制

    神经网络可以建立参数Kp,Ki,Kd自整定的PID控制器。基于BP神经网络的PID控制系统结构框图如下图所示:控制器由两部分组成:经典增量式
    发表于 09-07 07:43

    详细说明将TensorFlow Lite的微控制器应用程序移植到Arm Cortex-M55上的过程

    CMSIS-NN内核构建应用程序。CMSIS-NN 是高效的神经网络内核的集合,这些内核可以最
    发表于 06-01 16:44

    AT32讲堂016 | AT32 MCU DSP使用案例和网络神经算法CMSIS-NN案例

    ()参考AT32_DSP_DEMOprojectat_start_f403aexamples5_11_arm_variance_exampleCMSIS NN with DSP介绍本用户手册介绍了CMSIS NN软件库,这是一个
    发表于 08-16 19:40

    ARM Cortex-M系列芯片神经网络推理库CMSIS-NN详解

    1、ARM Cortex-M系列芯片神经网络推理库CMSIS-NN详解CMSIS-NN是用于ARM Cortex-M系列的芯片的神经网络推理库,用于低
    发表于 08-19 16:06

    CMSIS-NN版本转换Arm Cortex-M的神经网络:r0p0指南

    2. 概览 本指南向您展示了如何将神经网络从任何框架转换成一个基于 Arm Cortex-M-M 装置的实施工具, 使用 Arm CMSIS- NN 库。 此教程用于不再支持的 CMSIS
    发表于 08-11 07:06

    基于PLC的神经网络PID控制器设计

    为了改善工业控制系统的动态调节品质,运用BP 神经网络控制算法设计了一种神经网络PID 控制器,并给出了基于西门子PLC 的
    发表于 08-10 11:12 43次下载

    基于CMSIS-NN内核神经网络推理运算 对运行时间/吞吐量和能效有显著提升

    想到Arm Cortex-M系列处理内核,那么如果您想要强化它的性能并且减少内存消耗,CMSIS-NN就是您最好的选择。基于CMSIS-NN
    的头像 发表于 01-31 11:29 1.1w次阅读
    基于<b class='flag-5'>CMSIS-NN</b><b class='flag-5'>内核</b>的<b class='flag-5'>神经网络</b>推理运算 对运行时间/吞吐量和能效有显著<b class='flag-5'>提升</b>

    事隔五年之后,开启第2版DSP数字信号处理和CMSIS-NN神经网络教程,同步开启三代示波器,前50章发布(2021-11

    事隔五年之后,开启第2版DSP数字信号处理和CMSIS-NN神经网络教程,同步开启三代示波器,前50章发布(2021-11-02)
    发表于 11-26 10:36 0次下载
    事隔五年之后,开启第2版DSP数字信号处理和<b class='flag-5'>CMSIS-NN</b><b class='flag-5'>神经网络</b>教程,同步开启三代示波器,前50章发布(2021-11

    移植CMSIS-NN v6.0.0版本到VisionBoard

    CMSIS-NN是什么?官方的解释是:CMSISNNsoftwarelibraryisacollectionofefficientneuralnetworkkernelsdevelopedtomaximizetheperformanceandminimizethememoryfootprintofneuralnet
    的头像 发表于 07-10 08:35 672次阅读
    移植<b class='flag-5'>CMSIS-NN</b> v6.0.0版本到VisionBoard