From 2e3f4d2330094b4c8afd9872c2cf6765d69e5bdb Mon Sep 17 00:00:00 2001 From: Teresa Charlin Date: Wed, 29 Jul 2020 14:29:20 +0100 Subject: IVGCVSW-4713 Add EndToEnd test for RANK Signed-off-by: Teresa Charlin Change-Id: Ia8f237a2500986e01843defb75787694a20ba24c --- .../backendsCommon/test/RankEndToEndTestImpl.hpp | 64 ++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 src/backends/backendsCommon/test/RankEndToEndTestImpl.hpp (limited to 'src/backends/backendsCommon/test/RankEndToEndTestImpl.hpp') diff --git a/src/backends/backendsCommon/test/RankEndToEndTestImpl.hpp b/src/backends/backendsCommon/test/RankEndToEndTestImpl.hpp new file mode 100644 index 0000000000..a67bd46982 --- /dev/null +++ b/src/backends/backendsCommon/test/RankEndToEndTestImpl.hpp @@ -0,0 +1,64 @@ +// +// Copyright © 2020 Arm Ltd and Contributors. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#pragma once + +#include "CommonTestUtils.hpp" + +#include +#include + +#include + +namespace +{ + +armnn::INetworkPtr CreateRankNetwork(const armnn::TensorInfo& inputTensorInfo, + const armnn::TensorInfo& outputTensorInfo) +{ + armnn::INetworkPtr network(armnn::INetwork::Create()); + + armnn::IConnectableLayer* inputLayer = network->AddInputLayer(0, "Input"); + armnn::IConnectableLayer* rankLayer = network->AddRankLayer("Rank"); + armnn::IConnectableLayer* outputLayer = network->AddOutputLayer(0, "Output"); + + Connect(inputLayer, rankLayer, inputTensorInfo, 0, 0); + Connect(rankLayer, outputLayer, outputTensorInfo, 0, 0); + + return network; +} + +template> +void RankEndToEnd(const std::vector& backends) +{ + using namespace armnn; + + std::vector floatInputData{ + 1, 2, 3, 4, 5, + 11, 12, 13, 14, 15, + 21, 22, 23, 24, 25 + }; + std::vector inputData = armnnUtils::QuantizedVector(floatInputData); + + std::vector expectedOutputData{ 4 }; + + TensorInfo inputInfo ({ 1, 1, 5, 3 }, ArmnnType); + TensorShape outputShape (Dimensionality::Scalar); + TensorInfo outputInfo(outputShape, DataType::Signed32); + + armnn::INetworkPtr network = CreateRankNetwork(inputInfo, outputInfo); + + BOOST_TEST_CHECKPOINT("create a network"); + + std::map> inputTensorData = {{ 0, inputData }}; + std::map> expectedOutputTensorData = {{ 0, expectedOutputData }}; + + EndToEndLayerTestImpl(move(network), + inputTensorData, + expectedOutputTensorData, + backends); +} + +} // anonymous namespace \ No newline at end of file -- cgit v1.2.1