From d25af6786c0a714f2b4f099d0338dab17a5dc7e1 Mon Sep 17 00:00:00 2001 From: Manuel Bottini Date: Wed, 10 Jul 2019 17:06:12 +0100 Subject: COMPMID-2456: NEDeconvolutionLayer.cpp, NHWC is not supported Support of NHWC for NEDeconvolutionLayer Bugfix for QASYMM8 in CPPUpsample when offset is different than 0 QASYMM8 tests added in NEUpsample with offset different than 0 Change-Id: I8283fa5e5e323fd4d5777136359ddb33025674bb Signed-off-by: Manuel Bottini Reviewed-on: https://review.mlplatform.org/c/1517 Comments-Addressed: Arm Jenkins Tested-by: Arm Jenkins Reviewed-by: Pablo Marquez --- tests/validation/fixtures/UpsampleLayerFixture.h | 67 +++++++++++++++++++----- 1 file changed, 54 insertions(+), 13 deletions(-) (limited to 'tests/validation/fixtures/UpsampleLayerFixture.h') diff --git a/tests/validation/fixtures/UpsampleLayerFixture.h b/tests/validation/fixtures/UpsampleLayerFixture.h index 40229e2866..0a72e44dad 100644 --- a/tests/validation/fixtures/UpsampleLayerFixture.h +++ b/tests/validation/fixtures/UpsampleLayerFixture.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018 ARM Limited. + * Copyright (c) 2018-2019 ARM Limited. * * SPDX-License-Identifier: MIT * @@ -40,37 +40,51 @@ namespace test namespace validation { template -class UpsampleLayerFixture : public framework::Fixture +class UpsampleLayerFixtureBase : public framework::Fixture { public: template void setup(TensorShape input_shape, DataType data_type, DataLayout data_layout, - Size2D info, const InterpolationPolicy &policy) + Size2D info, const InterpolationPolicy &policy, QuantizationInfo quantization_info) { _data_type = data_type; - _target = compute_target(input_shape, info, policy, data_type, data_layout); - _reference = compute_reference(input_shape, info, policy, data_type); + _target = compute_target(input_shape, info, policy, data_type, data_layout, quantization_info); + _reference = compute_reference(input_shape, info, policy, data_type, quantization_info); } protected: template void fill(U &&tensor, int i) { - library->fill_tensor_uniform(tensor, i); + if(_data_type == DataType::QASYMM8) + { + const auto bounds = get_quantized_bounds(tensor.quantization_info(), -1.0f, 1.0f); + std::uniform_int_distribution distribution(bounds.first, bounds.second); + library->fill(tensor, distribution, i); + } + else + { + library->fill_tensor_uniform(tensor, i); + } } - TensorType compute_target(TensorShape input_shape, - const Size2D &info, const InterpolationPolicy &policy, DataType data_type, DataLayout data_layout) + TensorType compute_target(TensorShape input_shape, const Size2D &info, const InterpolationPolicy &policy, + DataType data_type, DataLayout data_layout, QuantizationInfo quantization_info) { + TensorShape output_shape(input_shape); + output_shape.set(0, info.x() * input_shape[0]); + output_shape.set(1, info.y() * input_shape[1]); + if(data_layout == DataLayout::NHWC) { permute(input_shape, PermutationVector(2U, 0U, 1U)); + permute(output_shape, PermutationVector(2U, 0U, 1U)); } // Create tensors - TensorType src = create_tensor(input_shape, data_type, 1, QuantizationInfo(), data_layout); - TensorType dst; + TensorType src = create_tensor(input_shape, data_type, 1, quantization_info, data_layout); + TensorType dst = create_tensor(output_shape, data_type, 1, quantization_info, data_layout); // Create and configure function FunctionType upsample; @@ -95,11 +109,11 @@ protected: return dst; } - SimpleTensor compute_reference(const TensorShape &input_shape, - const Size2D &info, const InterpolationPolicy &policy, DataType data_type) + SimpleTensor compute_reference(const TensorShape &input_shape, const Size2D &info, const InterpolationPolicy &policy, + DataType data_type, QuantizationInfo quantization_info) { // Create reference - SimpleTensor src{ input_shape, data_type }; + SimpleTensor src{ input_shape, data_type, 1, quantization_info }; // Fill reference fill(src, 0); @@ -111,6 +125,33 @@ protected: SimpleTensor _reference{}; DataType _data_type{}; }; + +template +class UpsampleLayerFixture : public UpsampleLayerFixtureBase +{ +public: + template + void setup(TensorShape input_shape, DataType data_type, DataLayout data_layout, + Size2D info, const InterpolationPolicy &policy) + { + UpsampleLayerFixtureBase::setup(input_shape, data_type, data_layout, + info, policy, QuantizationInfo()); + } +}; + +template +class UpsampleLayerQuantizedFixture : public UpsampleLayerFixtureBase +{ +public: + template + void setup(TensorShape input_shape, DataType data_type, DataLayout data_layout, + Size2D info, const InterpolationPolicy &policy, QuantizationInfo quantization_info) + { + UpsampleLayerFixtureBase::setup(input_shape, data_type, data_layout, + info, policy, quantization_info); + } +}; + } // namespace validation } // namespace test } // namespace arm_compute -- cgit v1.2.1