Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 1 | // |
| 2 | // Copyright © 2017 Arm Ltd. All rights reserved. |
| 3 | // SPDX-License-Identifier: MIT |
| 4 | // |
| 5 | |
| 6 | #include "SerializerUtils.hpp" |
| 7 | |
| 8 | namespace armnnSerializer |
| 9 | { |
| 10 | |
Aron Virginas-Tar | e80ebd1 | 2019-10-17 16:11:54 +0100 | [diff] [blame] | 11 | armnnSerializer::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 Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 30 | |
James Conroy | aba90cd | 2020-11-06 16:28:18 +0000 | [diff] [blame] | 31 | armnnSerializer::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 Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 45 | armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType) |
Mike Kelly | a0766c3 | 2019-02-19 17:22:07 +0000 | [diff] [blame] | 46 | { |
| 47 | switch (dataType) |
| 48 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 49 | case armnn::DataType::Float32: |
| 50 | case armnn::DataType::Signed32: |
| 51 | return armnnSerializer::ConstTensorData::ConstTensorData_IntData; |
| 52 | case armnn::DataType::Float16: |
Derek Lamberti | f90c56d | 2020-01-10 17:14:08 +0000 | [diff] [blame] | 53 | case armnn::DataType::QSymmS16: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 54 | return armnnSerializer::ConstTensorData::ConstTensorData_ShortData; |
Derek Lamberti | f90c56d | 2020-01-10 17:14:08 +0000 | [diff] [blame] | 55 | case armnn::DataType::QAsymmU8: |
Sadik Armagan | 1a84fe3 | 2020-03-27 15:56:57 +0000 | [diff] [blame] | 56 | case armnn::DataType::QSymmS8: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 57 | case armnn::DataType::Boolean: |
| 58 | return armnnSerializer::ConstTensorData::ConstTensorData_ByteData; |
Mike Kelly | a0766c3 | 2019-02-19 17:22:07 +0000 | [diff] [blame] | 59 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 60 | return armnnSerializer::ConstTensorData::ConstTensorData_NONE; |
Mike Kelly | a0766c3 | 2019-02-19 17:22:07 +0000 | [diff] [blame] | 61 | } |
| 62 | } |
| 63 | |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 64 | armnnSerializer::DataType GetFlatBufferDataType(armnn::DataType dataType) |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 65 | { |
| 66 | switch (dataType) |
| 67 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 68 | case armnn::DataType::Float32: |
| 69 | return armnnSerializer::DataType::DataType_Float32; |
| 70 | case armnn::DataType::Float16: |
| 71 | return armnnSerializer::DataType::DataType_Float16; |
| 72 | case armnn::DataType::Signed32: |
| 73 | return armnnSerializer::DataType::DataType_Signed32; |
Derek Lamberti | f90c56d | 2020-01-10 17:14:08 +0000 | [diff] [blame] | 74 | case armnn::DataType::QSymmS16: |
| 75 | return armnnSerializer::DataType::DataType_QSymmS16; |
Francis Murtagh | ddb1d06 | 2020-03-10 13:51:45 +0000 | [diff] [blame] | 76 | case armnn::DataType::QAsymmS8: |
| 77 | return armnnSerializer::DataType::DataType_QAsymmS8; |
Derek Lamberti | f90c56d | 2020-01-10 17:14:08 +0000 | [diff] [blame] | 78 | case armnn::DataType::QAsymmU8: |
| 79 | return armnnSerializer::DataType::DataType_QAsymmU8; |
Sadik Armagan | 1a84fe3 | 2020-03-27 15:56:57 +0000 | [diff] [blame] | 80 | case armnn::DataType::QSymmS8: |
| 81 | return armnnSerializer::DataType::DataType_QSymmS8; |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 82 | case armnn::DataType::Boolean: |
| 83 | return armnnSerializer::DataType::DataType_Boolean; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 84 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 85 | return armnnSerializer::DataType::DataType_Float16; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 86 | } |
| 87 | } |
| 88 | |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 89 | armnnSerializer::DataLayout GetFlatBufferDataLayout(armnn::DataLayout dataLayout) |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 90 | { |
| 91 | switch (dataLayout) |
| 92 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 93 | case armnn::DataLayout::NHWC: |
| 94 | return armnnSerializer::DataLayout::DataLayout_NHWC; |
| 95 | case armnn::DataLayout::NCHW: |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 96 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 97 | return armnnSerializer::DataLayout::DataLayout_NCHW; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 98 | } |
| 99 | } |
| 100 | |
josh minor | 4a3c610 | 2020-01-06 16:40:46 -0600 | [diff] [blame] | 101 | armnnSerializer::UnaryOperation GetFlatBufferUnaryOperation(armnn::UnaryOperation comparisonOperation) |
| 102 | { |
| 103 | switch (comparisonOperation) |
| 104 | { |
| 105 | case armnn::UnaryOperation::Abs: |
| 106 | return armnnSerializer::UnaryOperation::UnaryOperation_Abs; |
| 107 | case armnn::UnaryOperation::Rsqrt: |
| 108 | return armnnSerializer::UnaryOperation::UnaryOperation_Rsqrt; |
| 109 | case armnn::UnaryOperation::Sqrt: |
| 110 | return armnnSerializer::UnaryOperation::UnaryOperation_Sqrt; |
| 111 | case armnn::UnaryOperation::Exp: |
| 112 | return armnnSerializer::UnaryOperation::UnaryOperation_Exp; |
| 113 | case armnn::UnaryOperation::Neg: |
| 114 | return armnnSerializer::UnaryOperation::UnaryOperation_Neg; |
James Conroy | aba90cd | 2020-11-06 16:28:18 +0000 | [diff] [blame] | 115 | case armnn::UnaryOperation::LogicalNot: |
| 116 | return armnnSerializer::UnaryOperation::UnaryOperation_LogicalNot; |
josh minor | 4a3c610 | 2020-01-06 16:40:46 -0600 | [diff] [blame] | 117 | default: |
| 118 | throw armnn::InvalidArgumentException("Unary operation unknown"); |
| 119 | } |
| 120 | } |
| 121 | |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 122 | armnnSerializer::PoolingAlgorithm GetFlatBufferPoolingAlgorithm(armnn::PoolingAlgorithm poolingAlgorithm) |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 123 | { |
| 124 | switch (poolingAlgorithm) |
| 125 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 126 | case armnn::PoolingAlgorithm::Average: |
| 127 | return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Average; |
| 128 | case armnn::PoolingAlgorithm::L2: |
| 129 | return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_L2; |
| 130 | case armnn::PoolingAlgorithm::Max: |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 131 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 132 | return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Max; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 133 | } |
| 134 | } |
| 135 | |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 136 | armnnSerializer::OutputShapeRounding GetFlatBufferOutputShapeRounding(armnn::OutputShapeRounding outputShapeRounding) |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 137 | { |
| 138 | switch (outputShapeRounding) |
| 139 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 140 | case armnn::OutputShapeRounding::Ceiling: |
| 141 | return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Ceiling; |
| 142 | case armnn::OutputShapeRounding::Floor: |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 143 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 144 | return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Floor; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 145 | } |
| 146 | } |
| 147 | |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 148 | armnnSerializer::PaddingMethod GetFlatBufferPaddingMethod(armnn::PaddingMethod paddingMethod) |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 149 | { |
| 150 | switch (paddingMethod) |
| 151 | { |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 152 | case armnn::PaddingMethod::IgnoreValue: |
| 153 | return armnnSerializer::PaddingMethod::PaddingMethod_IgnoreValue; |
| 154 | case armnn::PaddingMethod::Exclude: |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 155 | default: |
Derek Lamberti | 0028d1b | 2019-02-20 13:57:42 +0000 | [diff] [blame] | 156 | return armnnSerializer::PaddingMethod::PaddingMethod_Exclude; |
Saoirse Stewart | 3166c3e | 2019-02-18 15:24:53 +0000 | [diff] [blame] | 157 | } |
| 158 | } |
| 159 | |
Nina Drozd | 5772878 | 2019-02-27 10:53:27 +0000 | [diff] [blame] | 160 | armnnSerializer::NormalizationAlgorithmChannel GetFlatBufferNormalizationAlgorithmChannel( |
| 161 | armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel) |
| 162 | { |
| 163 | switch (normalizationAlgorithmChannel) |
| 164 | { |
| 165 | case armnn::NormalizationAlgorithmChannel::Across: |
| 166 | return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across; |
| 167 | case armnn::NormalizationAlgorithmChannel::Within: |
| 168 | return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Within; |
| 169 | default: |
| 170 | return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across; |
| 171 | } |
| 172 | } |
| 173 | |
| 174 | armnnSerializer::NormalizationAlgorithmMethod GetFlatBufferNormalizationAlgorithmMethod( |
| 175 | armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod) |
| 176 | { |
| 177 | switch (normalizationAlgorithmMethod) |
| 178 | { |
| 179 | case armnn::NormalizationAlgorithmMethod::LocalBrightness: |
| 180 | return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness; |
| 181 | case armnn::NormalizationAlgorithmMethod::LocalContrast: |
| 182 | return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalContrast; |
| 183 | default: |
| 184 | return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness; |
| 185 | } |
| 186 | } |
| 187 | |
FinnWilliamsArm | 6fb339a | 2019-06-28 15:07:10 +0100 | [diff] [blame] | 188 | armnnSerializer::ResizeMethod GetFlatBufferResizeMethod(armnn::ResizeMethod method) |
| 189 | { |
| 190 | switch (method) |
| 191 | { |
| 192 | case armnn::ResizeMethod::NearestNeighbor: |
| 193 | return armnnSerializer::ResizeMethod_NearestNeighbor; |
| 194 | case armnn::ResizeMethod::Bilinear: |
| 195 | return armnnSerializer::ResizeMethod_Bilinear; |
| 196 | default: |
| 197 | return armnnSerializer::ResizeMethod_NearestNeighbor; |
| 198 | } |
| 199 | } |
| 200 | |
Sadik Armagan | 0c3ea5b | 2021-02-03 09:29:30 +0000 | [diff] [blame] | 201 | armnnSerializer::ReduceOperation GetFlatBufferReduceOperation(armnn::ReduceOperation reduceOperation) |
| 202 | { |
| 203 | switch (reduceOperation) |
| 204 | { |
| 205 | case armnn::ReduceOperation::Sum: |
| 206 | return armnnSerializer::ReduceOperation::ReduceOperation_Sum; |
| 207 | case armnn::ReduceOperation::Max: |
| 208 | return armnnSerializer::ReduceOperation::ReduceOperation_Max; |
| 209 | case armnn::ReduceOperation::Mean: |
| 210 | return armnnSerializer::ReduceOperation::ReduceOperation_Mean; |
| 211 | case armnn::ReduceOperation::Min: |
| 212 | return armnnSerializer::ReduceOperation::ReduceOperation_Min; |
| 213 | default: |
| 214 | return armnnSerializer::ReduceOperation::ReduceOperation_Sum; |
| 215 | } |
| 216 | } |
| 217 | |
Aron Virginas-Tar | e80ebd1 | 2019-10-17 16:11:54 +0100 | [diff] [blame] | 218 | } // namespace armnnSerializer |