From b6441e462e18e7e89c05b098d95dfcede90c9c7f Mon Sep 17 00:00:00 2001 From: Narumol Prangnawarat Date: Tue, 4 Jun 2019 11:22:00 +0100 Subject: Add support for all data type for input and output layers Signed-off-by: Narumol Prangnawarat Change-Id: I688f4db5f5950877ad88f637cf71c05270fd5338 --- src/backends/reference/RefLayerSupport.cpp | 13 ++----------- src/backends/reference/RefWorkloadFactory.cpp | 5 ++--- src/backends/reference/test/RefEndToEndTests.cpp | 10 ++++++++++ 3 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/backends/reference/RefLayerSupport.cpp b/src/backends/reference/RefLayerSupport.cpp index 1d0b230c77..edd552b2ac 100644 --- a/src/backends/reference/RefLayerSupport.cpp +++ b/src/backends/reference/RefLayerSupport.cpp @@ -701,10 +701,7 @@ bool RefLayerSupport::IsGreaterSupported(const TensorInfo& input0, bool RefLayerSupport::IsInputSupported(const TensorInfo& input, Optional reasonIfUnsupported) const { - return IsSupportedForDataTypeRef(reasonIfUnsupported, - input.GetDataType(), - &TrueFunc<>, - &TrueFunc<>); + return true; } bool RefLayerSupport::IsL2NormalizationSupported(const TensorInfo& input, @@ -950,13 +947,7 @@ bool RefLayerSupport::IsNormalizationSupported(const TensorInfo& input, bool RefLayerSupport::IsOutputSupported(const TensorInfo& output, Optional reasonIfUnsupported) const { - return IsSupportedForDataTypeGeneric(reasonIfUnsupported, - output.GetDataType(), - &TrueFunc<>, - &TrueFunc<>, - &TrueFunc<>, - &FalseFuncI32<>, - &TrueFunc<>); + return true; } bool RefLayerSupport::IsPadSupported(const TensorInfo& input, diff --git a/src/backends/reference/RefWorkloadFactory.cpp b/src/backends/reference/RefWorkloadFactory.cpp index 500c14b244..161065550d 100644 --- a/src/backends/reference/RefWorkloadFactory.cpp +++ b/src/backends/reference/RefWorkloadFactory.cpp @@ -87,7 +87,7 @@ std::unique_ptr RefWorkloadFactory::CreateInput(const InputQueueDescr throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count."); } - return MakeWorkload(descriptor, info); + return std::make_unique(descriptor, info); } std::unique_ptr RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor, @@ -106,8 +106,7 @@ std::unique_ptr RefWorkloadFactory::CreateOutput(const OutputQueueDes throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count."); } - return MakeWorkloadHelper(descriptor, info); + return std::make_unique(descriptor, info); } std::unique_ptr RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor, diff --git a/src/backends/reference/test/RefEndToEndTests.cpp b/src/backends/reference/test/RefEndToEndTests.cpp index 8e75eba021..885773d5e9 100644 --- a/src/backends/reference/test/RefEndToEndTests.cpp +++ b/src/backends/reference/test/RefEndToEndTests.cpp @@ -467,6 +467,16 @@ BOOST_AUTO_TEST_CASE(DequantizeEndToEndOffsetTest) DequantizeEndToEndOffset(defaultBackends); } +BOOST_AUTO_TEST_CASE(DequantizeEndToEndSimpleInt16Test) +{ + DequantizeEndToEndSimple(defaultBackends); +} + +BOOST_AUTO_TEST_CASE(DequantizeEndToEndOffsetInt16Test) +{ + DequantizeEndToEndOffset(defaultBackends); +} + BOOST_AUTO_TEST_CASE(RefDetectionPostProcessRegularNmsTest) { std::vector boxEncodings({ -- cgit v1.2.1