blob: bf4540a6d9883ea75018f9b27977e7f5bb425ab8 [file] [log] [blame]
Mike Kellyb5fdf382019-06-11 16:35:25 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
8#include "../ConversionUtils.hpp"
Kevin May42477c12020-03-26 13:34:14 +00009#include "../ConversionUtils_1_2.hpp"
Mike Kellyb5fdf382019-06-11 16:35:25 +010010
11#include <HalInterfaces.h>
12
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +010013#include <armnn/Types.hpp>
14
Kevin Mayec1e5b82020-02-26 17:00:39 +000015namespace V1_2 = ::android::hardware::neuralnetworks::V1_2;
16
Mike Kellyb5fdf382019-06-11 16:35:25 +010017namespace armnn_driver
18{
Pablo Tello6bf3f432021-09-01 15:30:10 +010019class DriverOptions;
Mike Kellyb5fdf382019-06-11 16:35:25 +010020namespace hal_1_2
21{
22
23class HalPolicy
24{
25public:
26 using Model = V1_2::Model;
27 using Operand = V1_2::Operand;
Aron Virginas-Tarcd700e42019-06-14 14:54:52 +010028 using OperandLifeTime = V1_0::OperandLifeTime;
29 using OperandType = V1_2::OperandType;
Mike Kellyb5fdf382019-06-11 16:35:25 +010030 using Operation = V1_2::Operation;
31 using OperationType = V1_2::OperationType;
32 using ExecutionCallback = V1_2::IExecutionCallback;
33 using getSupportedOperations_cb = V1_2::IDevice::getSupportedOperations_1_2_cb;
Kevin May42477c12020-03-26 13:34:14 +000034 using ErrorStatus = V1_0::ErrorStatus;
Pablo Tello6bf3f432021-09-01 15:30:10 +010035 using DeviceType = V1_2::DeviceType;
36
37 static DeviceType GetDeviceTypeFromOptions(const DriverOptions& options);
Mike Kellyb5fdf382019-06-11 16:35:25 +010038
39 static bool ConvertOperation(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tar24e699d2019-06-17 14:47:46 +010040
41private:
Mike Kelly46272802019-08-14 17:00:48 +010042 static bool ConvertAdd(const Operation& operation, const Model& model, ConversionData& data);
43
Francis Murtagh19fa0cc2019-11-19 12:06:47 +000044 static bool ConvertArgMinMax(const Operation& operation,
45 const Model& model,
46 ConversionData& data,
47 armnn::ArgMinMaxFunction argMinMaxFunction);
48
Sadik Armagan15d63e22019-07-26 16:59:35 +010049 static bool ConvertAveragePool2d(const Operation& operation, const Model& model, ConversionData& data);
50
Finn Williams23b87b32019-07-30 11:44:05 +010051 static bool ConvertBatchToSpaceNd(const Operation& operation, const Model& model, ConversionData& data);
52
Sadik Armagan92b5fd12021-04-26 09:52:06 +010053 static bool ConvertCast(const Operation& operation, const Model& model, ConversionData& data);
54
Teresa Charlin7f5b51e2021-09-01 14:19:38 +010055 static bool ConvertChannelShuffle(const Operation& operation, const Model& model, ConversionData& data);
56
Aron Virginas-Tar3e0982b2019-10-29 14:25:09 +000057 static bool ConvertComparison(const Operation& operation,
58 const Model& model,
59 ConversionData& data,
60 armnn::ComparisonOperation comparisonOperation);
61
Mike Kellyb8805202019-07-31 17:25:43 +010062 static bool ConvertConcatenation(const Operation& operation, const Model& model, ConversionData& data);
63
Aron Virginas-Tar24e699d2019-06-17 14:47:46 +010064 static bool ConvertConv2d(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +010065
Aron Virginas-Tar8edb16d2019-10-01 13:34:59 +010066 static bool ConvertDepthToSpace(const Operation& operation, const Model& model, ConversionData& data);
67
Aron Virginas-Tar24e699d2019-06-17 14:47:46 +010068 static bool ConvertDepthwiseConv2d(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +010069
Mike Kelly46272802019-08-14 17:00:48 +010070 static bool ConvertDequantize(const Operation& operation, const Model& model, ConversionData& data);
71
72 static bool ConvertDiv(const Operation& operation, const Model& model, ConversionData& data);
73
Narumol Prangnawarat85f96542019-09-12 16:26:29 +010074 static bool ConvertExpandDims(const Operation& operation, const Model& model, ConversionData& data);
75
josh minor00a963b2020-01-08 11:55:35 -060076 static bool ConvertElementwiseUnary(const Operation& operation,
77 const Model& model,
78 ConversionData& data,
79 armnn::UnaryOperation unaryOperation);
80
Mike Kelly46272802019-08-14 17:00:48 +010081 static bool ConvertFloor(const Operation& operation, const Model& model, ConversionData& data);
82
83 static bool ConvertFullyConnected(const Operation& operation, const Model& model, ConversionData& data);
84
Teresa Charlinf931af92020-04-10 16:46:53 +010085 static bool ConvertGather(const Operation& operation, const Model& model, ConversionData& data);
86
Teresa Charlin8f6429d2019-10-01 13:10:15 +010087 static bool ConvertGroupedConv2d(const Operation& operation, const Model& model, ConversionData& data);
88
Aron Virginas-Tara2a73802019-10-09 15:30:40 +010089 static bool ConvertInstanceNormalization(const Operation& operation, const Model& model, ConversionData& data);
90
Mike Kelly46272802019-08-14 17:00:48 +010091 static bool ConvertL2Normalization(const Operation& operation, const Model& model, ConversionData& data);
92
Sadik Armagan15d63e22019-07-26 16:59:35 +010093 static bool ConvertL2Pool2d(const Operation& operation, const Model& model, ConversionData& data);
94
Mike Kelly46272802019-08-14 17:00:48 +010095 static bool ConvertLocalResponseNormalization(const Operation& operation,
96 const Model& model,
97 ConversionData& data);
98
99 static bool ConvertLogistic(const Operation& operation, const Model& model, ConversionData& data);
100
Aron Virginas-Tar75e67792019-10-15 13:33:03 +0100101 static bool ConvertLogSoftmax(const Operation& operation, const Model& model, ConversionData& data);
102
Mike Kelly46272802019-08-14 17:00:48 +0100103 static bool ConvertLstm(const Operation& operation, const Model& model, ConversionData& data);
104
Sadik Armagan15d63e22019-07-26 16:59:35 +0100105 static bool ConvertMaxPool2d(const Operation& operation, const Model& model, ConversionData& data);
106
Narumol Prangnawarat95b1ef62019-07-15 12:02:20 +0100107 static bool ConvertMaximum(const Operation& operation, const Model& model, ConversionData& data);
108
Sadik Armagan6a284532021-03-12 09:12:29 +0000109 static bool ConvertMean(const Operation& operation, const Model& model, ConversionData& data);
Mike Kelly46272802019-08-14 17:00:48 +0100110
Ellen Norris-Thompson1cb29aa2019-07-11 17:27:37 +0100111 static bool ConvertMinimum(const Operation& operation, const Model& model, ConversionData& data);
112
Mike Kelly46272802019-08-14 17:00:48 +0100113 static bool ConvertMul(const Operation& operation, const Model& model, ConversionData& data);
114
Aron Virginas-Tarc921f6b2019-07-25 10:14:33 +0100115 static bool ConvertPad(const Operation& operation, const Model& model, ConversionData& data);
116
Aron Virginas-Tarcb8ac842019-07-05 15:47:07 +0100117 static bool ConvertPadV2(const Operation& operation, const Model& model, ConversionData& data);
118
Matteo Martincigh17ffff32019-06-27 14:12:55 +0100119 static bool ConvertPrelu(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +0100120
Sadik Armagan5a476a82019-07-30 09:43:18 +0100121 static bool ConvertQuantize(const Operation& operation, const Model& model, ConversionData& data);
122
Sadik Armagan813f2302020-05-19 14:10:30 +0100123 static bool ConvertQuantized16BitLstm(const Operation& operation, const Model& model, ConversionData& data);
Ellen Norris-Thompson7efb46d2019-07-24 17:39:19 +0100124
Sadik Armagan6a284532021-03-12 09:12:29 +0000125 static bool ConvertReduce(const Operation& operation,
126 const Model& model,
127 ConversionData& data,
128 ReduceOperation reduce_operation);
129
Sadik Armagan61113162019-07-25 09:09:40 +0100130 static bool ConvertReLu(const Operation& operation, const Model& model, ConversionData& data);
131
132 static bool ConvertReLu1(const Operation& operation, const Model& model, ConversionData& data);
133
134 static bool ConvertReLu6(const Operation& operation, const Model& model, ConversionData& data);
135
Mike Kelly46272802019-08-14 17:00:48 +0100136 static bool ConvertReshape(const Operation& operation, const Model& model, ConversionData& data);
137
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +0100138 static bool ConvertResize(const Operation& operation,
139 const Model& model,
140 ConversionData& data,
141 armnn::ResizeMethod resizeMethod);
Keith Davisa6bc52f2019-06-26 09:39:49 +0100142
Francis Murtagh074c25a2019-07-22 16:40:57 +0100143 static bool ConvertSoftmax(const Operation& operation, const Model& model, ConversionData& data);
144
Finn Williamsd74c5052019-07-30 17:06:00 +0100145 static bool ConvertSpaceToBatchNd(const Operation& operation, const Model& model, ConversionData& data);
146
Keith Davisa6bc52f2019-06-26 09:39:49 +0100147 static bool ConvertSpaceToDepth(const Operation& operation, const Model& model, ConversionData& data);
Sadik Armagan61113162019-07-25 09:09:40 +0100148
Sadik Armagan701d9a02019-09-04 15:16:18 +0100149 static bool ConvertSqrt(const Operation& operation, const Model& model, ConversionData& data);
150
Mike Kelly46272802019-08-14 17:00:48 +0100151 static bool ConvertSqueeze(const Operation& operation, const Model& model, ConversionData& data);
152
153 static bool ConvertStridedSlice(const Operation& operation, const Model& model, ConversionData& data);
154
Mike Kelly0a879362019-07-29 16:56:31 +0100155 static bool ConvertSub(const Operation& operation, const Model& model, ConversionData& data);
156
Sadik Armagan61113162019-07-25 09:09:40 +0100157 static bool ConvertTanH(const Operation& operation, const Model& model, ConversionData& data);
Ferran Balaguerb2397fd2019-07-25 12:12:39 +0100158
Mike Kelly46272802019-08-14 17:00:48 +0100159 static bool ConvertTranspose(const Operation& operation, const Model& model, ConversionData& data);
David Monahan613b49c2019-06-27 11:37:47 +0100160
Aron Virginas-Tar8b991682019-07-31 12:54:59 +0100161 static bool ConvertTransposeConv2d(const Operation& operation, const Model& model, ConversionData& data);
Cathal Corbett0fa5e6d2022-01-21 16:55:13 +0000162
163 static bool ConvertUnidirectionalSequenceLstm(const Operation& operation,
164 const Model& model,
165 ConversionData& data);
Mike Kellyb5fdf382019-06-11 16:35:25 +0100166};
167
168} // namespace hal_1_2
Matteo Martincigh17ffff32019-06-27 14:12:55 +0100169} // namespace armnn_driver