blob: fca6db84496282e9c27900763732021ec52e5151 [file] [log] [blame]
Saoirse Stewart3166c3e2019-02-18 15:24:53 +00001//
Mike Kelly1f140f72021-04-06 12:25:55 +01002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
Saoirse Stewart3166c3e2019-02-18 15:24:53 +00003// SPDX-License-Identifier: MIT
4//
5
6#include "SerializerUtils.hpp"
7
8namespace armnnSerializer
9{
10
Aron Virginas-Tare80ebd12019-10-17 16:11:54 +010011armnnSerializer::ComparisonOperation GetFlatBufferComparisonOperation(armnn::ComparisonOperation comparisonOperation)
12{
13 switch (comparisonOperation)
14 {
15 case armnn::ComparisonOperation::Equal:
16 return armnnSerializer::ComparisonOperation::ComparisonOperation_Equal;
17 case armnn::ComparisonOperation::Greater:
18 return armnnSerializer::ComparisonOperation::ComparisonOperation_Greater;
19 case armnn::ComparisonOperation::GreaterOrEqual:
20 return armnnSerializer::ComparisonOperation::ComparisonOperation_GreaterOrEqual;
21 case armnn::ComparisonOperation::Less:
22 return armnnSerializer::ComparisonOperation::ComparisonOperation_Less;
23 case armnn::ComparisonOperation::LessOrEqual:
24 return armnnSerializer::ComparisonOperation::ComparisonOperation_LessOrEqual;
25 case armnn::ComparisonOperation::NotEqual:
26 default:
27 return armnnSerializer::ComparisonOperation::ComparisonOperation_NotEqual;
28 }
29}
Saoirse Stewart3166c3e2019-02-18 15:24:53 +000030
James Conroyaba90cd2020-11-06 16:28:18 +000031armnnSerializer::LogicalBinaryOperation GetFlatBufferLogicalBinaryOperation(
32 armnn::LogicalBinaryOperation logicalBinaryOperation)
33{
34 switch (logicalBinaryOperation)
35 {
36 case armnn::LogicalBinaryOperation::LogicalAnd:
37 return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalAnd;
38 case armnn::LogicalBinaryOperation::LogicalOr:
39 return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalOr;
40 default:
41 throw armnn::InvalidArgumentException("Logical Binary operation unknown");
42 }
43}
44
Derek Lamberti0028d1b2019-02-20 13:57:42 +000045armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType)
Mike Kellya0766c32019-02-19 17:22:07 +000046{
47 switch (dataType)
48 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +000049 case armnn::DataType::Float32:
50 case armnn::DataType::Signed32:
51 return armnnSerializer::ConstTensorData::ConstTensorData_IntData;
52 case armnn::DataType::Float16:
Derek Lambertif90c56d2020-01-10 17:14:08 +000053 case armnn::DataType::QSymmS16:
Derek Lamberti0028d1b2019-02-20 13:57:42 +000054 return armnnSerializer::ConstTensorData::ConstTensorData_ShortData;
Teresa Charlin8e0d6082021-03-14 15:05:32 +000055 case armnn::DataType::QAsymmS8:
Derek Lambertif90c56d2020-01-10 17:14:08 +000056 case armnn::DataType::QAsymmU8:
Sadik Armagan1a84fe32020-03-27 15:56:57 +000057 case armnn::DataType::QSymmS8:
Derek Lamberti0028d1b2019-02-20 13:57:42 +000058 case armnn::DataType::Boolean:
59 return armnnSerializer::ConstTensorData::ConstTensorData_ByteData;
Mike Kelly1f140f72021-04-06 12:25:55 +010060 case armnn::DataType::Signed64:
61 return armnnSerializer::ConstTensorData::ConstTensorData_LongData;
Mike Kellya0766c32019-02-19 17:22:07 +000062 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +000063 return armnnSerializer::ConstTensorData::ConstTensorData_NONE;
Mike Kellya0766c32019-02-19 17:22:07 +000064 }
65}
66
Derek Lamberti0028d1b2019-02-20 13:57:42 +000067armnnSerializer::DataType GetFlatBufferDataType(armnn::DataType dataType)
Saoirse Stewart3166c3e2019-02-18 15:24:53 +000068{
69 switch (dataType)
70 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +000071 case armnn::DataType::Float32:
72 return armnnSerializer::DataType::DataType_Float32;
73 case armnn::DataType::Float16:
74 return armnnSerializer::DataType::DataType_Float16;
75 case armnn::DataType::Signed32:
76 return armnnSerializer::DataType::DataType_Signed32;
Mike Kelly1f140f72021-04-06 12:25:55 +010077 case armnn::DataType::Signed64:
78 return armnnSerializer::DataType::DataType_Signed64;
Derek Lambertif90c56d2020-01-10 17:14:08 +000079 case armnn::DataType::QSymmS16:
80 return armnnSerializer::DataType::DataType_QSymmS16;
Francis Murtaghddb1d062020-03-10 13:51:45 +000081 case armnn::DataType::QAsymmS8:
82 return armnnSerializer::DataType::DataType_QAsymmS8;
Derek Lambertif90c56d2020-01-10 17:14:08 +000083 case armnn::DataType::QAsymmU8:
84 return armnnSerializer::DataType::DataType_QAsymmU8;
Sadik Armagan1a84fe32020-03-27 15:56:57 +000085 case armnn::DataType::QSymmS8:
86 return armnnSerializer::DataType::DataType_QSymmS8;
Derek Lamberti0028d1b2019-02-20 13:57:42 +000087 case armnn::DataType::Boolean:
88 return armnnSerializer::DataType::DataType_Boolean;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +000089 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +000090 return armnnSerializer::DataType::DataType_Float16;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +000091 }
92}
93
Derek Lamberti0028d1b2019-02-20 13:57:42 +000094armnnSerializer::DataLayout GetFlatBufferDataLayout(armnn::DataLayout dataLayout)
Saoirse Stewart3166c3e2019-02-18 15:24:53 +000095{
96 switch (dataLayout)
97 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +000098 case armnn::DataLayout::NHWC:
99 return armnnSerializer::DataLayout::DataLayout_NHWC;
Matthew Sloyanb63a3112021-09-08 13:05:51 +0100100 case armnn::DataLayout::NDHWC:
101 return armnnSerializer::DataLayout::DataLayout_NDHWC;
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000102 case armnn::DataLayout::NCHW:
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000103 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000104 return armnnSerializer::DataLayout::DataLayout_NCHW;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000105 }
106}
107
josh minor4a3c6102020-01-06 16:40:46 -0600108armnnSerializer::UnaryOperation GetFlatBufferUnaryOperation(armnn::UnaryOperation comparisonOperation)
109{
110 switch (comparisonOperation)
111 {
112 case armnn::UnaryOperation::Abs:
113 return armnnSerializer::UnaryOperation::UnaryOperation_Abs;
114 case armnn::UnaryOperation::Rsqrt:
115 return armnnSerializer::UnaryOperation::UnaryOperation_Rsqrt;
116 case armnn::UnaryOperation::Sqrt:
117 return armnnSerializer::UnaryOperation::UnaryOperation_Sqrt;
118 case armnn::UnaryOperation::Exp:
119 return armnnSerializer::UnaryOperation::UnaryOperation_Exp;
120 case armnn::UnaryOperation::Neg:
121 return armnnSerializer::UnaryOperation::UnaryOperation_Neg;
James Conroyaba90cd2020-11-06 16:28:18 +0000122 case armnn::UnaryOperation::LogicalNot:
123 return armnnSerializer::UnaryOperation::UnaryOperation_LogicalNot;
Teresa Charlin50de4fa2021-05-31 18:47:33 +0100124 case armnn::UnaryOperation::Log:
125 return armnnSerializer::UnaryOperation::UnaryOperation_Log;
126 case armnn::UnaryOperation::Sin:
127 return armnnSerializer::UnaryOperation::UnaryOperation_Sin;
josh minor4a3c6102020-01-06 16:40:46 -0600128 default:
129 throw armnn::InvalidArgumentException("Unary operation unknown");
130 }
131}
132
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000133armnnSerializer::PoolingAlgorithm GetFlatBufferPoolingAlgorithm(armnn::PoolingAlgorithm poolingAlgorithm)
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000134{
135 switch (poolingAlgorithm)
136 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000137 case armnn::PoolingAlgorithm::Average:
138 return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Average;
139 case armnn::PoolingAlgorithm::L2:
140 return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_L2;
141 case armnn::PoolingAlgorithm::Max:
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000142 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000143 return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Max;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000144 }
145}
146
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000147armnnSerializer::OutputShapeRounding GetFlatBufferOutputShapeRounding(armnn::OutputShapeRounding outputShapeRounding)
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000148{
149 switch (outputShapeRounding)
150 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000151 case armnn::OutputShapeRounding::Ceiling:
152 return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Ceiling;
153 case armnn::OutputShapeRounding::Floor:
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000154 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000155 return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Floor;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000156 }
157}
158
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000159armnnSerializer::PaddingMethod GetFlatBufferPaddingMethod(armnn::PaddingMethod paddingMethod)
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000160{
161 switch (paddingMethod)
162 {
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000163 case armnn::PaddingMethod::IgnoreValue:
164 return armnnSerializer::PaddingMethod::PaddingMethod_IgnoreValue;
165 case armnn::PaddingMethod::Exclude:
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000166 default:
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000167 return armnnSerializer::PaddingMethod::PaddingMethod_Exclude;
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000168 }
169}
170
Nina Drozd57728782019-02-27 10:53:27 +0000171armnnSerializer::NormalizationAlgorithmChannel GetFlatBufferNormalizationAlgorithmChannel(
172 armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel)
173{
174 switch (normalizationAlgorithmChannel)
175 {
176 case armnn::NormalizationAlgorithmChannel::Across:
177 return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
178 case armnn::NormalizationAlgorithmChannel::Within:
179 return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Within;
180 default:
181 return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
182 }
183}
184
185armnnSerializer::NormalizationAlgorithmMethod GetFlatBufferNormalizationAlgorithmMethod(
186 armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod)
187{
188 switch (normalizationAlgorithmMethod)
189 {
190 case armnn::NormalizationAlgorithmMethod::LocalBrightness:
191 return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
192 case armnn::NormalizationAlgorithmMethod::LocalContrast:
193 return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalContrast;
194 default:
195 return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
196 }
197}
198
FinnWilliamsArm6fb339a2019-06-28 15:07:10 +0100199armnnSerializer::ResizeMethod GetFlatBufferResizeMethod(armnn::ResizeMethod method)
200{
201 switch (method)
202 {
203 case armnn::ResizeMethod::NearestNeighbor:
204 return armnnSerializer::ResizeMethod_NearestNeighbor;
205 case armnn::ResizeMethod::Bilinear:
206 return armnnSerializer::ResizeMethod_Bilinear;
207 default:
208 return armnnSerializer::ResizeMethod_NearestNeighbor;
209 }
210}
211
Sadik Armagan0c3ea5b2021-02-03 09:29:30 +0000212armnnSerializer::ReduceOperation GetFlatBufferReduceOperation(armnn::ReduceOperation reduceOperation)
213{
214 switch (reduceOperation)
215 {
216 case armnn::ReduceOperation::Sum:
217 return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
218 case armnn::ReduceOperation::Max:
219 return armnnSerializer::ReduceOperation::ReduceOperation_Max;
220 case armnn::ReduceOperation::Mean:
221 return armnnSerializer::ReduceOperation::ReduceOperation_Mean;
222 case armnn::ReduceOperation::Min:
223 return armnnSerializer::ReduceOperation::ReduceOperation_Min;
Teresa Charlin4e3e8312021-08-05 12:34:37 +0100224 case armnn::ReduceOperation::Prod:
225 return armnnSerializer::ReduceOperation::ReduceOperation_Prod;
Sadik Armagan0c3ea5b2021-02-03 09:29:30 +0000226 default:
227 return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
228 }
229}
230
Aron Virginas-Tare80ebd12019-10-17 16:11:54 +0100231} // namespace armnnSerializer