blob: 094c47c5ab9cbe7e4f9e92cfaa51aa5d7ef8ff66 [file] [log] [blame]
arovir01b0717b52018-09-05 17:03:25 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
Matteo Martincigh8b287c22018-09-07 09:25:10 +01008#include "../ConversionUtils.hpp"
arovir01b0717b52018-09-05 17:03:25 +01009
10#include <HalInterfaces.h>
11
12namespace V1_0 = ::android::hardware::neuralnetworks::V1_0;
13
14namespace armnn_driver
15{
16namespace hal_1_0
17{
18
19class HalPolicy
20{
21public:
22 using Model = V1_0::Model;
Matthew Bentham912b3622019-05-03 15:49:14 +010023 using Operand = V1_0::Operand;
Aron Virginas-Tarcd700e42019-06-14 14:54:52 +010024 using OperandLifeTime = V1_0::OperandLifeTime;
Matthew Bentham912b3622019-05-03 15:49:14 +010025 using OperandType = V1_0::OperandType;
arovir01b0717b52018-09-05 17:03:25 +010026 using Operation = V1_0::Operation;
Nikhil Raj77605822018-09-03 11:25:56 +010027 using OperationType = V1_0::OperationType;
arovir01b0717b52018-09-05 17:03:25 +010028 using getSupportedOperations_cb = V1_0::IDevice::getSupportedOperations_cb;
29
30 static bool ConvertOperation(const Operation& operation, const Model& model, ConversionData& data);
31
32private:
33 static bool ConvertAdd(const Operation& operation, const Model& model, ConversionData& data);
34
35 static bool ConvertAveragePool2d(const Operation& operation, const Model& model, ConversionData& data);
36
37 static bool ConvertConcatenation(const Operation& operation, const Model& model, ConversionData& data);
38
David Monahanacf479a2019-05-29 14:27:04 +010039 static bool ConvertDequantize(const Operation& operation, const Model& model, ConversionData& data);
40
arovir01b0717b52018-09-05 17:03:25 +010041 static bool ConvertFloor(const Operation& operation, const Model& model, ConversionData& data);
42
43 static bool ConvertFullyConnected(const Operation& operation, const Model& model, ConversionData& data);
44
45 static bool ConvertLocalResponseNormalization(const Operation& operation,
46 const Model& model,
47 ConversionData& data);
48
49 static bool ConvertLogistic(const Operation& operation, const Model& model, ConversionData& data);
50
51 static bool ConvertLstm(const Operation& operation, const Model& model, ConversionData& data);
52
53 static bool ConvertL2Normalization(const Operation& operation, const Model& model, ConversionData& data);
54
55 static bool ConvertL2Pool2d(const Operation& operation, const Model& model, ConversionData& data);
56
57 static bool ConvertMaxPool2d(const Operation& operation, const Model& model, ConversionData& data);
58
59 static bool ConvertMul(const Operation& operation, const Model& model, ConversionData& data);
60
61 static bool ConvertReLu(const Operation& operation, const Model& model, ConversionData& data);
62
63 static bool ConvertReLu1(const Operation& operation, const Model& model, ConversionData& data);
64
65 static bool ConvertReLu6(const Operation& operation, const Model& model, ConversionData& data);
66
67 static bool ConvertSoftmax(const Operation& operation, const Model& model, ConversionData& data);
68
69 static bool ConvertTanH(const Operation& operation, const Model& model, ConversionData& data);
70
71 static bool ConvertReshape(const Operation& operation, const Model& model, ConversionData& data);
72
73 static bool ConvertResizeBilinear(const Operation& operation, const Model& model, ConversionData& data);
Mike Kellyb5fdf382019-06-11 16:35:25 +010074
75 static bool ValidateConv2dParameters(const Operation& operation);
76
77 static bool ValidateDepthwiseConv2dParameters(const Operation& operation);
arovir01b0717b52018-09-05 17:03:25 +010078};
79
80} // namespace hal_1_0
81} // namespace armnn_driver