From d5e65c71261fd42d3e69478507fbfcc8cf36befc Mon Sep 17 00:00:00 2001 From: Michele Di Giorgio Date: Wed, 26 Jul 2017 17:09:17 +0100 Subject: COMPMID-456: Add support for QS16 NEON Normalization Layer. Change-Id: I1e542808cfd7774c67cc4e9a58e42449e4fb29aa Reviewed-on: http://mpd-gerrit.cambridge.arm.com/81735 Tested-by: Kaizen Reviewed-by: Anthony Barbier --- tests/validation_new/NEON/NormalizationLayer.cpp | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'tests/validation_new/NEON/NormalizationLayer.cpp') diff --git a/tests/validation_new/NEON/NormalizationLayer.cpp b/tests/validation_new/NEON/NormalizationLayer.cpp index f364975332..dfe793131a 100644 --- a/tests/validation_new/NEON/NormalizationLayer.cpp +++ b/tests/validation_new/NEON/NormalizationLayer.cpp @@ -50,7 +50,8 @@ constexpr float tolerance_f16 = 0.001f; #endif /* ARM_COMPUTE_ENABLE_FP16 */ constexpr float tolerance_f32 = 0.00001f; /** Tolerance for fixed point operations */ -constexpr int8_t tolerance_qs8 = 2; +constexpr int8_t tolerance_qs8 = 2; +constexpr int16_t tolerance_qs16 = 3; /** Input data set. */ const auto NormalizationDataset = combine(combine(combine(datasets::SmallShapes(), datasets::NormalizationTypes()), framework::dataset::make("NormalizationSize", 3, 9, 2)), @@ -116,6 +117,24 @@ FIXTURE_DATA_TEST_CASE(RunLarge, NENormalizationLayerFixedPointFixture, validate(Accessor(_target), _reference, tolerance_qs8); } TEST_SUITE_END() + +TEST_SUITE(QS16) +// Testing for fixed point position [1,14) as reciprocal limits the maximum fixed point position to 14 +FIXTURE_DATA_TEST_CASE(RunSmall, NENormalizationLayerFixedPointFixture, framework::DatasetMode::PRECOMMIT, combine(combine(NormalizationDataset, framework::dataset::make("DataType", + DataType::QS16)), + framework::dataset::make("FractionalBits", 1, 14))) +{ + // Validate output + validate(Accessor(_target), _reference, tolerance_qs16); +} +FIXTURE_DATA_TEST_CASE(RunLarge, NENormalizationLayerFixedPointFixture, framework::DatasetMode::NIGHTLY, combine(combine(NormalizationDataset, framework::dataset::make("DataType", + DataType::QS16)), + framework::dataset::make("FractionalBits", 1, 14))) +{ + // Validate output + validate(Accessor(_target), _reference, tolerance_qs16); +} +TEST_SUITE_END() TEST_SUITE_END() TEST_SUITE_END() -- cgit v1.2.1