Arm NN is an inference engine for CPUs, GPUs and NPUs. It bridges the gap between existing NN frameworks and the underlying IP. It enables efficient translation of existing neural network frameworks, such as TensorFlow and Caffe, allowing them to run efficiently, without modification, across Arm Cortex-A CPUs, Arm Mali GPUs and Arm Ethos NPUs.
Arm NN is free of charge.
About Arm NN SDK
Arm NN SDK is a set of open-source Linux software and tools that enables machine learning workloads on power-efficient devices. It provides a bridge between existing neural network frameworks and power-efficient Cortex-A CPUs, Arm Mali GPUs and Arm Ethos NPUs.
The latest release supports Caffe, TensorFlow, TensorFlow Lite, and ONNX. Arm NN takes networks from these frameworks, translates them to the internal Arm NN format and then, through the Compute Library, deploys them efficiently on Cortex-A CPUs, and, if present, Mali GPUs such as the Mali-G71 and Mali-G72.
Arm NN for Android
Also available is Arm NN for NNAPI, Google’s interface for accelerating neural networks on Android devices, made available in Android O. By default, NNAPI runs neural network workloads on the device’s CPU cores, but also provides a Hardware Abstraction Layer (HAL) that can target other processor types, such as GPUs. Arm NN for Android NNAPI provides this HAL for Mali GPUs. A further release adds support for Arm Ethos-N NPUs.
Arm support for Android NNAPI gives >4x performance boost.
Download Arm NN for Android sources.
Arm NN performance relative to other NN frameworks
- Arm NN open-source collaboration enables optimal third-party implementations
- Deployed in multiple production devices (>250Mu)
Support for Cortex-M CPUs
Machine learning support for Cortex-M microcontrollers is provided by TensorFlow Lite Micro. Further optimization is available via CMSIS-NN, a collection of efficient neural network kernels developed to maximize the performance and minimize the memory footprint of neural networks on Cortex-M processor cores.Download CMSIS-NN
Arm NN future roadmap
Future releases of Arm NN will enable support for other machine learning frameworks as inputs, and other forms of processor cores as targets. This includes processor cores and accelerators from Arm’s partners, assuming availability of suitable extensions.
Webinar - Project Trillium: Optimizing ML Performance for any Application
Project Trillium is a suite of Arm IP designed to deliver scalable ML and neural network functionality at any point on the performance curve, from sensors, to mobile, and beyond.
|Suggested answer||Cortex-M3 Registers||0 votes||641 views||9 replies||Latest 17 hours ago by Andy Neil||Answer this|
|Answered||FPB BreakPoint(without Debugger)||0 votes||146 views||3 replies||Latest yesterday by 42Bastian Schick||Answer this|
|Answered||Make MPU be uniprocessor system||0 votes||422 views||3 replies||Latest yesterday by 42Bastian Schick||Answer this|
|Answered||Trouble configuring MMU for 2MB block mapping||0 votes||903 views||1 replies||Latest yesterday by jcal93||Answer this|
|Suggested answer||unable to wake up from power down mode in lpc2148 using external interrupt||0 votes||71 views||1 replies||Latest yesterday by Andy Neil||Answer this|
|Suggested answer||axi ordering||0 votes||2366 views||5 replies||Latest 2 days ago by Colin Campbell||Answer this|
|Suggested answer||Cortex-M3 Registers Latest 17 hours ago by Andy Neil||9 replies 641 views|
|Answered||FPB BreakPoint(without Debugger) Latest yesterday by 42Bastian Schick||3 replies 146 views|
|Answered||Make MPU be uniprocessor system Latest yesterday by 42Bastian Schick||3 replies 422 views|
|Answered||Trouble configuring MMU for 2MB block mapping Latest yesterday by jcal93||1 replies 903 views|
|Suggested answer||unable to wake up from power down mode in lpc2148 using external interrupt Latest yesterday by Andy Neil||1 replies 71 views|
|Suggested answer||axi ordering Latest 2 days ago by Colin Campbell||5 replies 2366 views|