From 574775c7fa78a094bbeb7f9f87aca832936884e2 Mon Sep 17 00:00:00 2001 From: Georgios Pinitas Date: Mon, 18 Feb 2019 20:08:02 +0000 Subject: COMPMID-1937: Adds support for DequantizationLayer for NEON/CL. Change-Id: I4b73edd176a277294e0e42e642460bc61210778a Signed-off-by: Georgios Pinitas Reviewed-on: https://review.mlplatform.org/c/744 Tested-by: Arm Jenkins Reviewed-by: Giuseppe Rossini --- tests/validation/reference/DequantizationLayer.cpp | 32 +++++++--------------- 1 file changed, 10 insertions(+), 22 deletions(-) (limited to 'tests/validation/reference/DequantizationLayer.cpp') diff --git a/tests/validation/reference/DequantizationLayer.cpp b/tests/validation/reference/DequantizationLayer.cpp index 33096a1d81..df50c14ec7 100644 --- a/tests/validation/reference/DequantizationLayer.cpp +++ b/tests/validation/reference/DequantizationLayer.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017 ARM Limited. + * Copyright (c) 2017-2019 ARM Limited. * * SPDX-License-Identifier: MIT * @@ -31,36 +31,24 @@ namespace validation { namespace reference { -template ::value, int>::type> -SimpleTensor dequantization_layer(const SimpleTensor &src, const SimpleTensor &min_max) +template +SimpleTensor dequantization_layer(const SimpleTensor &src) { - // Create reference - SimpleTensor dst{ src.shape(), DataType::F32 }; + const DataType dst_data_type = std::is_same::value ? DataType::F32 : DataType::F16; + const QuantizationInfo &quantization_info = src.quantization_info(); - // Compute reference - const int width = src.shape().x(); - const int height = src.shape().y(); - const int depth = src.shape().z(); - const int stride_w = width * height * depth; - const int num_batches = min_max.shape().total_size_upper(1); + SimpleTensor dst{ src.shape(), dst_data_type }; - for(int k = 0; k < num_batches; ++k) + for(int i = 0; i < src.num_elements(); ++i) { - const float min = min_max[k * 2 + 0]; - const float max = min_max[k * 2 + 1]; - const float range = max - min; - const float scaling = range / 255.0f; - - for(int i = 0; i < stride_w; ++i) - { - dst[i + k * stride_w] = (static_cast(src[i + k * stride_w]) * scaling) + min; - } + dst[i] = static_cast(quantization_info.dequantize(src[i])); } return dst; } -template SimpleTensor dequantization_layer(const SimpleTensor &src, const SimpleTensor &min_max); +template SimpleTensor dequantization_layer(const SimpleTensor &src); +template SimpleTensor dequantization_layer(const SimpleTensor &src); } // namespace reference } // namespace validation } // namespace test -- cgit v1.2.1