diff options
author | Narumol Prangnawarat <narumol.prangnawarat@arm.com> | 2019-09-16 17:00:22 +0100 |
---|---|---|
committer | Narumol Prangnawarat <narumol.prangnawarat@arm.com> | 2019-09-16 17:00:54 +0100 |
commit | 4dc64a69ba383ece509d442598617445a3b4847f (patch) | |
tree | b50cb259594aa0cf634a4c37657a2c7a50be0c6c /src/backends/reference/test/ArgMinMaxTests.cpp | |
parent | a0c7871cf140d1e9cf59a213626ee534c0122c7f (diff) | |
download | armnn-4dc64a69ba383ece509d442598617445a3b4847f.tar.gz |
IVGCVSW-3694 Add ArgMinMax implementation for Ref
* Add ArgMinMax implementation
* Add utility function to get number of elements between axis
* Add utility function to get unsigned axis
* Unit tests for ArgMinMax function
Signed-off-by: Narumol Prangnawarat <narumol.prangnawarat@arm.com>
Change-Id: I7bc3d610dda9526190187eb87394a8ed7a4b5cdd
Diffstat (limited to 'src/backends/reference/test/ArgMinMaxTests.cpp')
-rw-r--r-- | src/backends/reference/test/ArgMinMaxTests.cpp | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/src/backends/reference/test/ArgMinMaxTests.cpp b/src/backends/reference/test/ArgMinMaxTests.cpp new file mode 100644 index 0000000000..201a2c0c2e --- /dev/null +++ b/src/backends/reference/test/ArgMinMaxTests.cpp @@ -0,0 +1,58 @@ +// +// Copyright © 2019 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include <reference/workloads/ArgMinMax.hpp> + +#include <boost/test/unit_test.hpp> + +BOOST_AUTO_TEST_SUITE(RefArgMinMax) + +BOOST_AUTO_TEST_CASE(ArgMinTest) +{ + const armnn::TensorInfo inputInfo({ 1, 2, 3 } , armnn::DataType::Float32); + const armnn::TensorInfo outputInfo({ 1, 3 }, armnn::DataType::Float32); + + std::vector<float> inputValues({ 1.0f, 5.0f, 3.0f, 4.0f, 2.0f, 6.0f}); + std::vector<int32_t> outputValues(outputInfo.GetNumElements()); + std::vector<int32_t> expectedValues({ 0, 1, 0 }); + + ArgMinMax(*armnn::MakeDecoder<float>(inputInfo, inputValues.data()), + outputValues.data(), + inputInfo, + outputInfo, + armnn::ArgMinMaxFunction::Min, + -2); + + BOOST_CHECK_EQUAL_COLLECTIONS(outputValues.begin(), + outputValues.end(), + expectedValues.begin(), + expectedValues.end()); + +} + +BOOST_AUTO_TEST_CASE(ArgMaxTest) +{ + const armnn::TensorInfo inputInfo({ 1, 2, 3 } , armnn::DataType::Float32); + const armnn::TensorInfo outputInfo({ 1, 3 }, armnn::DataType::Float32); + + std::vector<float> inputValues({ 1.0f, 5.0f, 3.0f, 4.0f, 2.0f, 6.0f }); + std::vector<int32_t> outputValues(outputInfo.GetNumElements()); + std::vector<int32_t> expectedValues({ 1, 0, 1 }); + + ArgMinMax(*armnn::MakeDecoder<float>(inputInfo, inputValues.data()), + outputValues.data(), + inputInfo, + outputInfo, + armnn::ArgMinMaxFunction::Max, + -2); + + BOOST_CHECK_EQUAL_COLLECTIONS(outputValues.begin(), + outputValues.end(), + expectedValues.begin(), + expectedValues.end()); + +} + +BOOST_AUTO_TEST_SUITE_END()
\ No newline at end of file |