commit | 75e677939a98298e50d65c4a7e99a03fb51d5e3c | [log] [tgz] |
---|---|---|
author | Aron Virginas-Tar <Aron.Virginas-Tar@arm.com> | Tue Oct 15 13:33:03 2019 +0100 |
committer | Aron Virginas-Tar <Aron.Virginas-Tar@arm.com> | Tue Oct 15 13:33:03 2019 +0100 |
tree | 69a32790256c26a94a45f31641179a37373f0bc8 | |
parent | ad7545385e42bd183f6d27bfea30a57f76a1fb46 [diff] |
IVGCVSW-3894 Add support for LOG_SOFTMAX to the HAL 1.2 driver Signed-off-by: Aron Virginas-Tar <Aron.Virginas-Tar@arm.com> Change-Id: I59645b339f3b176e5d0852769acb95f5657101d3
This directory contains the ArmNN driver for the Android Neural Networks API, implementing the android.hardware.neuralnetworks@1.0, android.hardware.neuralnetworks@1.1 and android.hardware.neuralnetworks@1.2 HALs.
For more information about supported operations and configurations, see NnapiSupport.txt
<ANDROID_ROOT>
<ANDROID_ROOT>
<ANDROID_ROOT>/vendor/arm/android-nn-driver
system/vendor/bin/hw
directory in the Android image. To update the build environment, add to the contents of the variable PRODUCT_PACKAGES
within the device-specific makefile that is located in the <ANDROID_ROOT>/device/<manufacturer>/<product>
directory. This file is normally called device.mk
:For Android P or Q, using NN API version (1.0), the following should be added to device.mk
:
For Android P or Q, a new version of the NN API is available (1.1), thus the following should be added to device.mk
instead:
For Android Q, a new version of the NN API is available (1.2), thus the following should be added to device.mk
instead:
Similarly, the Neon, CL or reference backend can be enabled/disabled by setting ARMNN_COMPUTE_CL_ENABLE, ARMNN_COMPUTE_NEON_ENABLE or ARMNN_REF_ENABLE in device.mk
:
For Android P and Android Q the vendor manifest.xml requires the Neural Network HAL information. For Android P use HAL version 1.1 as below. For Android Q substitute 1.2 where necessary.
<hal format="hidl"> <name>android.hardware.neuralnetworks</name> <transport>hwbinder</transport> <version>1.1</version> <interface> <name>IDevice</name> <instance>armnn</instance> </interface> <fqname>@1.1::IDevice/armnn</fqname> </hal>
make
in <ANDROID_ROOT>
Android P
For example, if the ArmNN driver has been built with the NN API 1.0, check for the following file:
Android Q has a different path:
NeuralNetworksTest
unit tests (note this is an optional component that must be built).ArmnnDriver
tag.The GPU tuner is a feature of the Compute Library that finds optimum values for GPU acceleration tuning parameters. There are three levels of tuning: exhaustive, normal and rapid. Exhaustive means that all lws values are tested. Normal means that a reduced number of lws values are tested, but that generally is sufficient to have a performance close enough to the exhaustive approach. Rapid means that only 3 lws values should be tested for each kernel. The recommended way of using it with ArmNN is to generate the tuning data during development of the Android image for a device, and use it in read-only mode during normal operation:
The android-nn-driver is provided under the MIT license. See LICENSE for more information. Contributions to this project are accepted under the same license.
Individual files contain the following tag instead of the full license text.
SPDX-License-Identifier: MIT
This enables machine processing of license information based on the SPDX License Identifiers that are available here: http://spdx.org/licenses/