blob: 0662e1be2cd10fb7807ada98972bf105799352ae [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
Aron Virginas-Tar3e0982b2019-10-29 14:25:09 +000055 static bool ConvertComparison(const Operation& operation,
56 const Model& model,
57 ConversionData& data,
58 armnn::ComparisonOperation comparisonOperation);
59
Mike Kellyb8805202019-07-31 17:25:43 +010060 static bool ConvertConcatenation(const Operation& operation, const Model& model, ConversionData& data);
61
Aron Virginas-Tar24e699d2019-06-17 14:47:46 +010062 static bool ConvertConv2d(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +010063
Aron Virginas-Tar8edb16d2019-10-01 13:34:59 +010064 static bool ConvertDepthToSpace(const Operation& operation, const Model& model, ConversionData& data);
65
Aron Virginas-Tar24e699d2019-06-17 14:47:46 +010066 static bool ConvertDepthwiseConv2d(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +010067
Mike Kelly46272802019-08-14 17:00:48 +010068 static bool ConvertDequantize(const Operation& operation, const Model& model, ConversionData& data);
69
70 static bool ConvertDiv(const Operation& operation, const Model& model, ConversionData& data);
71
Narumol Prangnawarat85f96542019-09-12 16:26:29 +010072 static bool ConvertExpandDims(const Operation& operation, const Model& model, ConversionData& data);
73
josh minor00a963b2020-01-08 11:55:35 -060074 static bool ConvertElementwiseUnary(const Operation& operation,
75 const Model& model,
76 ConversionData& data,
77 armnn::UnaryOperation unaryOperation);
78
Mike Kelly46272802019-08-14 17:00:48 +010079 static bool ConvertFloor(const Operation& operation, const Model& model, ConversionData& data);
80
81 static bool ConvertFullyConnected(const Operation& operation, const Model& model, ConversionData& data);
82
Teresa Charlinf931af92020-04-10 16:46:53 +010083 static bool ConvertGather(const Operation& operation, const Model& model, ConversionData& data);
84
Teresa Charlin8f6429d2019-10-01 13:10:15 +010085 static bool ConvertGroupedConv2d(const Operation& operation, const Model& model, ConversionData& data);
86
Aron Virginas-Tara2a73802019-10-09 15:30:40 +010087 static bool ConvertInstanceNormalization(const Operation& operation, const Model& model, ConversionData& data);
88
Mike Kelly46272802019-08-14 17:00:48 +010089 static bool ConvertL2Normalization(const Operation& operation, const Model& model, ConversionData& data);
90
Sadik Armagan15d63e22019-07-26 16:59:35 +010091 static bool ConvertL2Pool2d(const Operation& operation, const Model& model, ConversionData& data);
92
Mike Kelly46272802019-08-14 17:00:48 +010093 static bool ConvertLocalResponseNormalization(const Operation& operation,
94 const Model& model,
95 ConversionData& data);
96
97 static bool ConvertLogistic(const Operation& operation, const Model& model, ConversionData& data);
98
Aron Virginas-Tar75e67792019-10-15 13:33:03 +010099 static bool ConvertLogSoftmax(const Operation& operation, const Model& model, ConversionData& data);
100
Mike Kelly46272802019-08-14 17:00:48 +0100101 static bool ConvertLstm(const Operation& operation, const Model& model, ConversionData& data);
102
Sadik Armagan15d63e22019-07-26 16:59:35 +0100103 static bool ConvertMaxPool2d(const Operation& operation, const Model& model, ConversionData& data);
104
Narumol Prangnawarat95b1ef62019-07-15 12:02:20 +0100105 static bool ConvertMaximum(const Operation& operation, const Model& model, ConversionData& data);
106
Sadik Armagan6a284532021-03-12 09:12:29 +0000107 static bool ConvertMean(const Operation& operation, const Model& model, ConversionData& data);
Mike Kelly46272802019-08-14 17:00:48 +0100108
Ellen Norris-Thompson1cb29aa2019-07-11 17:27:37 +0100109 static bool ConvertMinimum(const Operation& operation, const Model& model, ConversionData& data);
110
Mike Kelly46272802019-08-14 17:00:48 +0100111 static bool ConvertMul(const Operation& operation, const Model& model, ConversionData& data);
112
Aron Virginas-Tarc921f6b2019-07-25 10:14:33 +0100113 static bool ConvertPad(const Operation& operation, const Model& model, ConversionData& data);
114
Aron Virginas-Tarcb8ac842019-07-05 15:47:07 +0100115 static bool ConvertPadV2(const Operation& operation, const Model& model, ConversionData& data);
116
Matteo Martincigh17ffff32019-06-27 14:12:55 +0100117 static bool ConvertPrelu(const Operation& operation, const Model& model, ConversionData& data);
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +0100118
Sadik Armagan5a476a82019-07-30 09:43:18 +0100119 static bool ConvertQuantize(const Operation& operation, const Model& model, ConversionData& data);
120
Sadik Armagan813f2302020-05-19 14:10:30 +0100121 static bool ConvertQuantized16BitLstm(const Operation& operation, const Model& model, ConversionData& data);
Ellen Norris-Thompson7efb46d2019-07-24 17:39:19 +0100122
Sadik Armagan6a284532021-03-12 09:12:29 +0000123 static bool ConvertReduce(const Operation& operation,
124 const Model& model,
125 ConversionData& data,
126 ReduceOperation reduce_operation);
127
Sadik Armagan61113162019-07-25 09:09:40 +0100128 static bool ConvertReLu(const Operation& operation, const Model& model, ConversionData& data);
129
130 static bool ConvertReLu1(const Operation& operation, const Model& model, ConversionData& data);
131
132 static bool ConvertReLu6(const Operation& operation, const Model& model, ConversionData& data);
133
Mike Kelly46272802019-08-14 17:00:48 +0100134 static bool ConvertReshape(const Operation& operation, const Model& model, ConversionData& data);
135
Aron Virginas-Tarfb2fa292019-07-04 11:59:48 +0100136 static bool ConvertResize(const Operation& operation,
137 const Model& model,
138 ConversionData& data,
139 armnn::ResizeMethod resizeMethod);
Keith Davisa6bc52f2019-06-26 09:39:49 +0100140
Francis Murtagh074c25a2019-07-22 16:40:57 +0100141 static bool ConvertSoftmax(const Operation& operation, const Model& model, ConversionData& data);
142
Finn Williamsd74c5052019-07-30 17:06:00 +0100143 static bool ConvertSpaceToBatchNd(const Operation& operation, const Model& model, ConversionData& data);
144
Keith Davisa6bc52f2019-06-26 09:39:49 +0100145 static bool ConvertSpaceToDepth(const Operation& operation, const Model& model, ConversionData& data);
Sadik Armagan61113162019-07-25 09:09:40 +0100146
Sadik Armagan701d9a02019-09-04 15:16:18 +0100147 static bool ConvertSqrt(const Operation& operation, const Model& model, ConversionData& data);
148
Mike Kelly46272802019-08-14 17:00:48 +0100149 static bool ConvertSqueeze(const Operation& operation, const Model& model, ConversionData& data);
150
151 static bool ConvertStridedSlice(const Operation& operation, const Model& model, ConversionData& data);
152
Mike Kelly0a879362019-07-29 16:56:31 +0100153 static bool ConvertSub(const Operation& operation, const Model& model, ConversionData& data);
154
Sadik Armagan61113162019-07-25 09:09:40 +0100155 static bool ConvertTanH(const Operation& operation, const Model& model, ConversionData& data);
Ferran Balaguerb2397fd2019-07-25 12:12:39 +0100156
Mike Kelly46272802019-08-14 17:00:48 +0100157 static bool ConvertTranspose(const Operation& operation, const Model& model, ConversionData& data);
David Monahan613b49c2019-06-27 11:37:47 +0100158
Aron Virginas-Tar8b991682019-07-31 12:54:59 +0100159 static bool ConvertTransposeConv2d(const Operation& operation, const Model& model, ConversionData& data);
Mike Kellyb5fdf382019-06-11 16:35:25 +0100160};
161
162} // namespace hal_1_2
Matteo Martincigh17ffff32019-06-27 14:12:55 +0100163} // namespace armnn_driver