165 if (inputs.size() != 1)
167 throw armnn::Exception(
"ConvertHardSwishToTosaOperator: 1 input tensors required.");
170 if (outputs.size() != 1)
172 throw armnn::Exception(
"ConvertHardSwishToTosaOperator: 1 output tensor required.");
175 if (desc->m_Function != ActivationFunction::HardSwish)
177 throw armnn::Exception(
"ConvertHardSwishToTosaOperator ActivationDescriptor only supports function HardSwish.");
180 std::string inputName = std::string(
"input_");
181 std::string outputName = std::string(
"output0_");
186 if (layer !=
nullptr)
192 std::vector<TosaSerializationTensor*> tensors;
193 std::vector<TosaSerializationOperator*> operators;
195 DataType inputDType = inputs[0]->GetDataType();
197 bool isInt8 = (inputDType == DataType::QAsymmS8 || inputDType == DataType::QSymmS8);
200 float inputScale = inputs[0]->GetQuantizationScale();
201 float outputScale = outputs[0]->GetQuantizationScale();
202 int32_t inputZp = inputs[0]->GetQuantizationOffset();
203 int32_t outputZp = outputs[0]->GetQuantizationOffset();
205 TosaTableAttribute attribute(
207 operators.push_back(
new TosaSerializationOperator(tosa::Op_TABLE,
208 Attribute_TableAttribute,
215 throw Exception(
"ConvertHardSwishToTosaOperator() type currently unimplemented.");
221 std::vector<int32_t> inputShape0;
222 DType inputDType0 =
ArmNNToDType(inputs[0]->GetDataType());
223 if(inputName.find(
"input_") != std::string::npos)
226 tensors.push_back(
new TosaSerializationTensor(inputName, inputShape0, inputDType0, {}));
230 DType outputDType0 =
ArmNNToDType(outputs[0]->GetDataType());
231 tensors.push_back(
new TosaSerializationTensor(outputName, outputShape0, outputDType0, {}));
235 return new TosaSerializationBasicBlock(blockName,
std::vector< int16_t > getTosaConstHardSwish8bitTable(float inputScale, int32_t inputZp, float outputScale, int32_t outputZp)
std::string GenerateUniqueOutputName(const Layer &layer, uint32_t layerSlot=0)
const std::string mainName
DType ArmNNToDType(const DataType &type)
std::vector< int32_t > GetTosaTensorShape(const TensorShape &shape)
std::string GenerateUniqueInputName(const armnn::InputSlot &slot)
std::string GetUniqueTosaMappingID()
Base class for all ArmNN exceptions so that users can filter to just those.
const InputSlot & GetInputSlot(unsigned int index) const override
Get a const input slot handle by slot index.