blob: f19879621bb48146cc33d2c14337f97c5bae46eb [file] [log] [blame]
surmeh0149b9e102018-05-17 14:11:25 +01001------ ArmNN for Android NNAPI supported operations ------
telsoa015307bc12018-03-09 13:51:08 +00002
Matthew Benthama3e23ca2019-05-13 12:49:59 +01003This release of ArmNN for Android supports use as a driver for the Android Neural Networks API. It implements the
Aron Virginas-Tarb23732b2019-06-17 15:48:45 +01004android.hardware.neuralnetworks@1.0, android.hardware.neuralnetworks@1.1 and android.hardware.neuralnetworks@1.2
5HAL interfaces.
telsoa015307bc12018-03-09 13:51:08 +00006
7For more information on the Android Neural Networks API, see https://developer.android.com/ndk/guides/neuralnetworks/index.html
8
9For integration and usage documentation, please see README.md.
10
11--- Support for Android Neural Networks HAL operations ---
12
Sadik Armagan1ba99892019-08-21 15:03:44 +010013The following AndroidNN HAL 1.0, 1.1 and 1.2 operations are currently supported:
telsoa015307bc12018-03-09 13:51:08 +000014
15AndroidNN operator Tensor type supported
Matthew Benthamb92f8902019-06-05 09:24:31 +010016ADD (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000017AVERAGE_POOL_2D (FLOAT32,QUANT8_ASYMM)
Sadik Armagan82fbeb32018-12-20 17:12:26 +000018BATCH_TO_SPACE_ND (FLOAT32,QUANT8_ASYMM)
Matthew Benthamb92f8902019-06-05 09:24:31 +010019CONCATENATION (FLOAT32,QUANT8_ASYMM)
20CONV_2D (FLOAT32,QUANT8_ASYMM)
21DEPTHWISE_CONV_2D (FLOAT32,QUANT8_ASYMM)
22DIV (FLOAT32,QUANT8_ASYMM)
23DEQUANTIZE (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000024FLOOR (FLOAT32)
Matthew Bentham378333d2018-10-01 16:07:27 +010025FULLY_CONNECTED (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000026L2_NORMALIZATION (FLOAT32)
nikraj01c6494cc2019-05-22 16:30:44 +010027L2_POOL_2D (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000028LOCAL_RESPONSE_NORMALIZATION (FLOAT32)
Matthew Benthamb92f8902019-06-05 09:24:31 +010029LOGISTIC (FLOAT32,QUANT8_ASYMM)
Ferran Balaguerd04c0432018-11-15 14:48:05 +000030LSTM (FLOAT32)
Sadik Armagan1ba99892019-08-21 15:03:44 +010031MAXIMUM (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000032MAX_POOL_2D (FLOAT32,QUANT8_ASYMM)
Ferran Balaguerd04c0432018-11-15 14:48:05 +000033MEAN (FLOAT32,QUANT8_ASYMM)
Sadik Armagan1ba99892019-08-21 15:03:44 +010034MINIMUM (FLOAT32,QUANT8_ASYMM)
Matthew Benthamb92f8902019-06-05 09:24:31 +010035MUL (FLOAT32,QUANT8_ASYMM)
Ferran Balaguerd04c0432018-11-15 14:48:05 +000036PAD (FLOAT32,QUANT8_ASYMM)
Sadik Armagan1ba99892019-08-21 15:03:44 +010037PAD_V2 (FLOAT32,QUANT8_ASYMM)
38PRELU (FLOAT32,QUANT8_ASYMM)
39QUANTIZE (FLOAT32,QUANT8_ASYMM)
40QUANTIZED_16BIT_LSTM (QUANT8_ASYMM)
Matthew Benthamb92f8902019-06-05 09:24:31 +010041RELU (FLOAT32,QUANT8_ASYMM)
42RELU1 (FLOAT32,QUANT8_ASYMM)
43RELU6 (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000044RESHAPE (FLOAT32,QUANT8_ASYMM)
nikraj01c6494cc2019-05-22 16:30:44 +010045RESIZE_BILINEAR (FLOAT32,QUANT8_ASYMM)
Sadik Armagan1ba99892019-08-21 15:03:44 +010046RESIZE_NEAREST_NEIGHBOR (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000047SOFTMAX (FLOAT32,QUANT8_ASYMM)
Sadik Armagan82fbeb32018-12-20 17:12:26 +000048SPACE_TO_BATCH_ND (FLOAT32,QUANT8_ASYMM)
Keith Davisa6bc52f2019-06-26 09:39:49 +010049SPACE_TO_DEPTH_ND (FLOAT32,QUANT8_ASYMM)
saoste01b8471482018-10-10 09:44:51 +010050SQUEEZE (FLOAT32,QUANT8_ASYMM)
Sadik Armagan82fbeb32018-12-20 17:12:26 +000051STRIDED_SLICE (FLOAT32,QUANT8_ASYMM)
Matthew Benthamb92f8902019-06-05 09:24:31 +010052SUB (FLOAT32,QUANT8_ASYMM)
53TANH (FLOAT32,QUANT8_ASYMM)
saoste01fe463152018-10-18 17:49:56 +010054TRANSPOSE (FLOAT32,QUANT8_ASYMM)
David Monahan613b49c2019-06-27 11:37:47 +010055TRANSPOSE_CONV_2D (FLOAT32,QUANT8_ASYMM)
telsoa015307bc12018-03-09 13:51:08 +000056
Mike Kelly56df76c2019-06-14 15:51:39 +010057Where operations are not supported by the ArmNN Android NN Driver, the driver indicates this to the framework
58appropriately and the framework implements those operations using a CPU implementation.