ArmNN
 23.05
SerializerUtils.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017,2019-2021,2023 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "SerializerUtils.hpp"
7 
8 namespace armnnSerializer
9 {
10 
12 {
13  switch (comparisonOperation)
14  {
16  return armnnSerializer::ComparisonOperation::ComparisonOperation_Equal;
18  return armnnSerializer::ComparisonOperation::ComparisonOperation_Greater;
20  return armnnSerializer::ComparisonOperation::ComparisonOperation_GreaterOrEqual;
22  return armnnSerializer::ComparisonOperation::ComparisonOperation_Less;
24  return armnnSerializer::ComparisonOperation::ComparisonOperation_LessOrEqual;
26  default:
27  return armnnSerializer::ComparisonOperation::ComparisonOperation_NotEqual;
28  }
29 }
30 
32  armnn::LogicalBinaryOperation logicalBinaryOperation)
33 {
34  switch (logicalBinaryOperation)
35  {
37  return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalAnd;
39  return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalOr;
40  default:
41  throw armnn::InvalidArgumentException("Logical Binary operation unknown");
42  }
43 }
44 
45 armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType)
46 {
47  switch (dataType)
48  {
51  return armnnSerializer::ConstTensorData::ConstTensorData_IntData;
54  return armnnSerializer::ConstTensorData::ConstTensorData_ShortData;
59  return armnnSerializer::ConstTensorData::ConstTensorData_ByteData;
61  return armnnSerializer::ConstTensorData::ConstTensorData_LongData;
62  default:
63  return armnnSerializer::ConstTensorData::ConstTensorData_NONE;
64  }
65 }
66 
68 {
69  switch (dataType)
70  {
72  return armnnSerializer::DataType::DataType_Float32;
74  return armnnSerializer::DataType::DataType_Float16;
76  return armnnSerializer::DataType::DataType_Signed32;
78  return armnnSerializer::DataType::DataType_Signed64;
80  return armnnSerializer::DataType::DataType_QSymmS16;
82  return armnnSerializer::DataType::DataType_QAsymmS8;
84  return armnnSerializer::DataType::DataType_QAsymmU8;
86  return armnnSerializer::DataType::DataType_QSymmS8;
88  return armnnSerializer::DataType::DataType_Boolean;
89  default:
90  return armnnSerializer::DataType::DataType_Float16;
91  }
92 }
93 
95 {
96  switch (dataLayout)
97  {
99  return armnnSerializer::DataLayout::DataLayout_NHWC;
101  return armnnSerializer::DataLayout::DataLayout_NDHWC;
103  return armnnSerializer::DataLayout::DataLayout_NCDHW;
105  default:
106  return armnnSerializer::DataLayout::DataLayout_NCHW;
107  }
108 }
109 
111 {
112  switch (binaryOperation)
113  {
115  return armnnSerializer::BinaryOperation::BinaryOperation_Add;
117  return armnnSerializer::BinaryOperation::BinaryOperation_Div;
119  return armnnSerializer::BinaryOperation::BinaryOperation_Maximum;
121  return armnnSerializer::BinaryOperation::BinaryOperation_Minimum;
123  return armnnSerializer::BinaryOperation::BinaryOperation_Mul;
125  return armnnSerializer::BinaryOperation::BinaryOperation_Sub;
126  default:
127  throw armnn::InvalidArgumentException("Elementwise Binary operation unknown");
128  }
129 }
130 
132 {
133  switch (unaryOperation)
134  {
136  return armnnSerializer::UnaryOperation::UnaryOperation_Abs;
138  return armnnSerializer::UnaryOperation::UnaryOperation_Ceil;
140  return armnnSerializer::UnaryOperation::UnaryOperation_Rsqrt;
142  return armnnSerializer::UnaryOperation::UnaryOperation_Sqrt;
144  return armnnSerializer::UnaryOperation::UnaryOperation_Exp;
146  return armnnSerializer::UnaryOperation::UnaryOperation_Neg;
148  return armnnSerializer::UnaryOperation::UnaryOperation_LogicalNot;
150  return armnnSerializer::UnaryOperation::UnaryOperation_Log;
152  return armnnSerializer::UnaryOperation::UnaryOperation_Sin;
153  default:
154  throw armnn::InvalidArgumentException("Elementwise Unary operation unknown");
155  }
156 }
157 
159 {
160  switch (poolingAlgorithm)
161  {
163  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Average;
165  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_L2;
167  default:
168  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Max;
169  }
170 }
171 
173 {
174  switch (outputShapeRounding)
175  {
177  return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Ceiling;
179  default:
180  return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Floor;
181  }
182 }
183 
185 {
186  switch (paddingMethod)
187  {
189  return armnnSerializer::PaddingMethod::PaddingMethod_IgnoreValue;
191  default:
192  return armnnSerializer::PaddingMethod::PaddingMethod_Exclude;
193  }
194 }
195 
197 {
198  switch (paddingMode)
199  {
201  return armnnSerializer::PaddingMode::PaddingMode_Reflect;
203  return armnnSerializer::PaddingMode::PaddingMode_Symmetric;
204  default:
205  return armnnSerializer::PaddingMode::PaddingMode_Constant;
206  }
207 }
208 
210  armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel)
211 {
212  switch (normalizationAlgorithmChannel)
213  {
215  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
217  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Within;
218  default:
219  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
220  }
221 }
222 
224  armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod)
225 {
226  switch (normalizationAlgorithmMethod)
227  {
229  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
231  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalContrast;
232  default:
233  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
234  }
235 }
236 
238 {
239  switch (method)
240  {
242  return armnnSerializer::ResizeMethod_NearestNeighbor;
244  return armnnSerializer::ResizeMethod_Bilinear;
245  default:
246  return armnnSerializer::ResizeMethod_NearestNeighbor;
247  }
248 }
249 
251 {
252  switch (reduceOperation)
253  {
255  return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
257  return armnnSerializer::ReduceOperation::ReduceOperation_Max;
259  return armnnSerializer::ReduceOperation::ReduceOperation_Mean;
261  return armnnSerializer::ReduceOperation::ReduceOperation_Min;
263  return armnnSerializer::ReduceOperation::ReduceOperation_Prod;
264  default:
265  return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
266  }
267 }
268 
269 } // namespace armnnSerializer
armnn::ReduceOperation::Mean
@ Mean
armnn::NormalizationAlgorithmMethod
NormalizationAlgorithmMethod
Definition: Types.hpp:210
armnnSerializer::GetFlatBufferOutputShapeRounding
armnnSerializer::OutputShapeRounding GetFlatBufferOutputShapeRounding(armnn::OutputShapeRounding outputShapeRounding)
Definition: SerializerUtils.cpp:172
armnn::OutputShapeRounding::Ceiling
@ Ceiling
armnn::OutputShapeRounding
OutputShapeRounding
Definition: Types.hpp:218
armnn::DataType::QAsymmU8
@ QAsymmU8
armnnSerializer
Definition: ISerializer.hpp:11
armnn::NormalizationAlgorithmChannel
NormalizationAlgorithmChannel
Definition: Types.hpp:204
armnn::ComparisonOperation::Equal
@ Equal
SerializerUtils.hpp
armnn::DataLayout
DataLayout
Definition: Types.hpp:62
armnn::LogicalBinaryOperation::LogicalAnd
@ LogicalAnd
armnn::BinaryOperation
BinaryOperation
Definition: Types.hpp:137
armnn::DataType::Float16
@ Float16
armnn::OutputShapeRounding::Floor
@ Floor
armnn::NormalizationAlgorithmMethod::LocalContrast
@ LocalContrast
Jarret 2009: Local Contrast Normalization.
armnn::ComparisonOperation::NotEqual
@ NotEqual
armnnSerializer::GetFlatBufferLogicalBinaryOperation
armnnSerializer::LogicalBinaryOperation GetFlatBufferLogicalBinaryOperation(armnn::LogicalBinaryOperation logicalBinaryOperation)
Definition: SerializerUtils.cpp:31
armnn::UnaryOperation::Exp
@ Exp
armnn::UnaryOperation::Sqrt
@ Sqrt
armnn::DataType::Signed32
@ Signed32
armnnSerializer::GetFlatBufferUnaryOperation
armnnSerializer::UnaryOperation GetFlatBufferUnaryOperation(armnn::UnaryOperation unaryOperation)
Definition: SerializerUtils.cpp:131
armnn::UnaryOperation::Neg
@ Neg
armnn::ComparisonOperation::LessOrEqual
@ LessOrEqual
armnn::DataType::QAsymmS8
@ QAsymmS8
armnn::PaddingMethod::IgnoreValue
@ IgnoreValue
The padding fields count, but are ignored.
armnn::PoolingAlgorithm::L2
@ L2
armnn::NormalizationAlgorithmChannel::Within
@ Within
armnnSerializer::GetFlatBufferDataType
armnnSerializer::DataType GetFlatBufferDataType(armnn::DataType dataType)
Definition: SerializerUtils.cpp:67
armnn::ReduceOperation::Min
@ Min
armnn::BinaryOperation::Sub
@ Sub
armnnSerializer::GetFlatBufferPaddingMethod
armnnSerializer::PaddingMethod GetFlatBufferPaddingMethod(armnn::PaddingMethod paddingMethod)
Definition: SerializerUtils.cpp:184
armnn::LogicalBinaryOperation
LogicalBinaryOperation
Definition: Types.hpp:118
armnn::ResizeMethod::NearestNeighbor
@ NearestNeighbor
armnnSerializer::GetFlatBufferPoolingAlgorithm
armnnSerializer::PoolingAlgorithm GetFlatBufferPoolingAlgorithm(armnn::PoolingAlgorithm poolingAlgorithm)
Definition: SerializerUtils.cpp:158
armnn::PoolingAlgorithm
PoolingAlgorithm
Definition: Types.hpp:147
armnn::ResizeMethod
ResizeMethod
Definition: Types.hpp:163
armnn::ReduceOperation::Sum
@ Sum
armnn::LogicalBinaryOperation::LogicalOr
@ LogicalOr
armnn::UnaryOperation::Ceil
@ Ceil
armnnSerializer::GetFlatBufferComparisonOperation
armnnSerializer::ComparisonOperation GetFlatBufferComparisonOperation(armnn::ComparisonOperation comparisonOperation)
Definition: SerializerUtils.cpp:11
armnn::DataLayout::NCHW
@ NCHW
armnn::ReduceOperation::Max
@ Max
armnn::ReduceOperation
ReduceOperation
Definition: Types.hpp:154
armnn::NormalizationAlgorithmChannel::Across
@ Across
armnn::NormalizationAlgorithmMethod::LocalBrightness
@ LocalBrightness
Krichevsky 2012: Local Brightness Normalization.
armnnSerializer::GetFlatBufferBinaryOperation
armnnSerializer::BinaryOperation GetFlatBufferBinaryOperation(armnn::BinaryOperation binaryOperation)
Definition: SerializerUtils.cpp:110
armnn::BinaryOperation::Mul
@ Mul
armnn::DataLayout::NCDHW
@ NCDHW
armnn::ComparisonOperation::Greater
@ Greater
armnnSerializer::GetFlatBufferPaddingMode
armnnSerializer::PaddingMode GetFlatBufferPaddingMode(armnn::PaddingMode paddingMode)
Definition: SerializerUtils.cpp:196
armnn::ComparisonOperation::GreaterOrEqual
@ GreaterOrEqual
armnnSerializer::GetFlatBufferResizeMethod
armnnSerializer::ResizeMethod GetFlatBufferResizeMethod(armnn::ResizeMethod method)
Definition: SerializerUtils.cpp:237
armnn::DataType::Float32
@ Float32
armnn::ResizeMethod::Bilinear
@ Bilinear
armnn::ComparisonOperation
ComparisonOperation
Definition: Types.hpp:108
armnn::PaddingMode
PaddingMode
The padding mode controls whether the padding should be filled with constant values (Constant),...
Definition: Types.hpp:197
armnn::DataType::Signed64
@ Signed64
armnn::UnaryOperation
UnaryOperation
Definition: Types.hpp:124
armnnSerializer::GetFlatBufferNormalizationAlgorithmChannel
armnnSerializer::NormalizationAlgorithmChannel GetFlatBufferNormalizationAlgorithmChannel(armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel)
Definition: SerializerUtils.cpp:209
armnn::BinaryOperation::Minimum
@ Minimum
armnn::PaddingMethod
PaddingMethod
The padding method modifies the output of pooling layers.
Definition: Types.hpp:185
armnn::DataLayout::NHWC
@ NHWC
armnn::PaddingMode::Reflect
@ Reflect
armnn::BinaryOperation::Maximum
@ Maximum
armnn::UnaryOperation::Abs
@ Abs
armnn::BinaryOperation::Add
@ Add
armnn::DataType
DataType
Definition: Types.hpp:48
armnnSerializer::GetFlatBufferConstTensorData
armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType)
Definition: SerializerUtils.cpp:45
armnn::PaddingMode::Symmetric
@ Symmetric
armnn::PoolingAlgorithm::Max
@ Max
armnn::UnaryOperation::LogicalNot
@ LogicalNot
armnn::UnaryOperation::Sin
@ Sin
armnn::PoolingAlgorithm::Average
@ Average
armnn::DataType::QSymmS8
@ QSymmS8
armnnSerializer::GetFlatBufferReduceOperation
armnnSerializer::ReduceOperation GetFlatBufferReduceOperation(armnn::ReduceOperation reduceOperation)
Definition: SerializerUtils.cpp:250
armnnSerializer::GetFlatBufferDataLayout
armnnSerializer::DataLayout GetFlatBufferDataLayout(armnn::DataLayout dataLayout)
Definition: SerializerUtils.cpp:94
armnn::UnaryOperation::Rsqrt
@ Rsqrt
armnn::DataType::QSymmS16
@ QSymmS16
armnn::ReduceOperation::Prod
@ Prod
armnn::PaddingMethod::Exclude
@ Exclude
The padding fields don't count and are ignored.
armnn::DataLayout::NDHWC
@ NDHWC
armnn::DataType::Boolean
@ Boolean
armnn::InvalidArgumentException
Definition: Exceptions.hpp:80
armnn::BinaryOperation::Div
@ Div
armnn::ComparisonOperation::Less
@ Less
armnnSerializer::GetFlatBufferNormalizationAlgorithmMethod
armnnSerializer::NormalizationAlgorithmMethod GetFlatBufferNormalizationAlgorithmMethod(armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod)
Definition: SerializerUtils.cpp:223
armnn::UnaryOperation::Log
@ Log