From d0dfe178e3e6729cebd1a60d614f794e3c2ab72d Mon Sep 17 00:00:00 2001 From: Francis Murtagh Date: Tue, 25 Jun 2019 10:57:10 +0100 Subject: IVGCVSW-3249 Extend the BatchToSpace workload to support QSymm16 * Add reference supportedness validation checks. * Call unit tests with QSymm16 data type. Change-Id: Ie6621ca7072dfc69278198c53e09b090275a7fff Signed-off-by: Francis Murtagh --- src/backends/reference/RefLayerSupport.cpp | 47 +++++++++++++++++++++++++----- 1 file changed, 39 insertions(+), 8 deletions(-) (limited to 'src/backends/reference/RefLayerSupport.cpp') diff --git a/src/backends/reference/RefLayerSupport.cpp b/src/backends/reference/RefLayerSupport.cpp index 4e9a67879f..1f37420e42 100644 --- a/src/backends/reference/RefLayerSupport.cpp +++ b/src/backends/reference/RefLayerSupport.cpp @@ -359,14 +359,45 @@ bool RefLayerSupport::IsBatchToSpaceNdSupported(const TensorInfo& input, Optional reasonIfUnsupported) const { ignore_unused(descriptor); - return (IsSupportedForDataTypeRef(reasonIfUnsupported, - input.GetDataType(), - &TrueFunc<>, - &TrueFunc<>) && - IsSupportedForDataTypeRef(reasonIfUnsupported, - output.GetDataType(), - &TrueFunc<>, - &TrueFunc<>)); + + bool supported = true; + + std::string batchToSpaceNdLayerStr = "batchToSpaceNd"; + std::string inputTensorStr = "input"; + std::string outputTensorStr = "output"; + + // Define supported types. + std::array supportedTypes = + { + DataType::Float32, + DataType::QuantisedAsymm8, + DataType::QuantisedSymm16 + }; + + supported &= CheckSupportRule(TypeAnyOf(input, supportedTypes), reasonIfUnsupported, + "Reference BatchToSpaceNd: input type not supported."); + + supported &= CheckSupportRule(TypeAnyOf(output, supportedTypes), reasonIfUnsupported, + "Reference BatchToSpaceNd: output type not supported."); + + supported &= CheckSupportRule(TypesAreEqual(input, output), reasonIfUnsupported, + "Reference BatchToSpaceNd: input and output types mismatched."); + + supported &= CheckSupportRule(TensorNumDimensionsAreCorrect(output, 4), + reasonIfUnsupported, + CreateIncorrectDimensionsErrorMsg(4, + output.GetNumDimensions(), + batchToSpaceNdLayerStr, + outputTensorStr).data()); + + supported &= CheckSupportRule(TensorNumDimensionsAreCorrect(input, 4), + reasonIfUnsupported, + CreateIncorrectDimensionsErrorMsg(4, + input.GetNumDimensions(), + batchToSpaceNdLayerStr, + inputTensorStr).data()); + + return supported; } bool RefLayerSupport::IsConcatSupported(const std::vector inputs, -- cgit v1.2.1