From 85584760476adb9d73172747729f03b381b5eacf Mon Sep 17 00:00:00 2001 From: Aleksandr Voron Date: Wed, 20 Sep 2023 15:57:34 +0200 Subject: [PATCH] [CPU] [ARM] Enable SoftMax SLT tests on ARM (#19823) --- .../single_layer_tests/classes/softmax.cpp | 75 ++++++++++++++++ .../single_layer_tests/classes/softmax.hpp | 41 +++++++++ .../{ => instances/common}/softmax.cpp | 89 ++----------------- 3 files changed, 122 insertions(+), 83 deletions(-) create mode 100644 src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.cpp create mode 100644 src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.hpp rename src/plugins/intel_cpu/tests/functional/single_layer_tests/{ => instances/common}/softmax.cpp (72%) diff --git a/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.cpp b/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.cpp new file mode 100644 index 00000000000000..ac8a7149f88253 --- /dev/null +++ b/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.cpp @@ -0,0 +1,75 @@ +// Copyright (C) 2023 Intel Corporation +// SPDX-License-Identifier: Apache-2.0 +// + +#include "softmax.hpp" +#include "gtest/gtest.h" +#include "test_utils/cpu_test_utils.hpp" + +using namespace InferenceEngine; +using namespace CPUTestUtils; +using namespace ngraph::helpers; +using namespace ov::test; + +namespace CPULayerTestsDefinitions { + +std::string SoftMaxLayerCPUTest::getTestCaseName(const testing::TestParamInfo& obj) { + CPUSpecificParams cpuParams; + ElementType inType; + SoftMaxConfig config; + std::string targetDevice; + std::tie(inType, config, targetDevice, cpuParams) = obj.param; + + std::ostringstream result; + result << "netPRC=" << inType << "_"; + result << "IS=" << ov::test::utils::partialShape2str({config.inputShape.first}) << "_"; + result << "TS="; + for (const auto& shape : config.inputShape.second) { + result << "("; + result << ov::test::utils::vec2str(shape); + result << ")_"; + } + result << "axis=" << config.axis << "_"; + result << "trgDev=" << targetDevice; + result << CPUTestsBase::getTestCaseName(cpuParams); + + return result.str(); +} + +void SoftMaxLayerCPUTest::SetUp() { + ElementType inType; + SoftMaxConfig config; + CPUSpecificParams cpuParams; + std::tie(inType, config, targetDevice, cpuParams) = this->GetParam(); + + std::tie(inFmts, outFmts, priority, selectedType) = cpuParams; + if (selectedType.empty()) { + selectedType = getPrimitiveType(); + } + + if (inType == ElementType::bf16) { + rel_threshold = 2e-2f; + } + selectedType = makeSelectedTypeStr(selectedType, inType); + init_input_shapes({config.inputShape}); + ov::ParameterVector params; + for (auto&& shape : inputDynamicShapes) { + params.push_back(std::make_shared(inType, shape)); + } + const auto paramOuts = + ngraph::helpers::convert2OutputVector(ngraph::helpers::castOps2Nodes(params)); + + const auto softMax = std::make_shared(paramOuts.at(0), config.axis); + + function = makeNgraphFunction(inType, params, softMax, "SoftMax"); +} + +TEST_P(SoftMaxLayerCPUTest, CompareWithRefs) { + run(); + CheckPluginRelatedResults(compiledModel, "Softmax"); +} + +namespace SoftMax { + +} // namespace SoftMax +} // namespace CPULayerTestsDefinitions diff --git a/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.hpp b/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.hpp new file mode 100644 index 00000000000000..5465d1c06859c0 --- /dev/null +++ b/src/plugins/intel_cpu/tests/functional/single_layer_tests/classes/softmax.hpp @@ -0,0 +1,41 @@ +// Copyright (C) 2018-2023 Intel Corporation +// SPDX-License-Identifier: Apache-2.0 +// + +#include + +#include "shared_test_classes/base/ov_subgraph.hpp" +#include "test_utils/cpu_test_utils.hpp" + +using namespace InferenceEngine; +using namespace CPUTestUtils; +using namespace ov::test; + +namespace CPULayerTestsDefinitions { + +struct SoftMaxConfig { + ov::test::InputShape inputShape; + size_t axis; +}; + +typedef std::tuple + softmaxCPUTestParams; + +class SoftMaxLayerCPUTest : public testing::WithParamInterface, + virtual public SubgraphBaseTest, + public CPUTestsBase { +public: + static std::string getTestCaseName(const testing::TestParamInfo& obj); + +protected: + void SetUp() override; +}; + +namespace SoftMax { + + +} // namespace SoftMax +} // namespace CPULayerTestsDefinitions diff --git a/src/plugins/intel_cpu/tests/functional/single_layer_tests/softmax.cpp b/src/plugins/intel_cpu/tests/functional/single_layer_tests/instances/common/softmax.cpp similarity index 72% rename from src/plugins/intel_cpu/tests/functional/single_layer_tests/softmax.cpp rename to src/plugins/intel_cpu/tests/functional/single_layer_tests/instances/common/softmax.cpp index 70484a14b25c73..03655fd40a536d 100644 --- a/src/plugins/intel_cpu/tests/functional/single_layer_tests/softmax.cpp +++ b/src/plugins/intel_cpu/tests/functional/single_layer_tests/instances/common/softmax.cpp @@ -1,93 +1,17 @@ -// Copyright (C) 2018-2023 Intel Corporation +// Copyright (C) 2023 Intel Corporation // SPDX-License-Identifier: Apache-2.0 // -#include - -#include "shared_test_classes/base/ov_subgraph.hpp" +#include "single_layer_tests/classes/softmax.hpp" #include "test_utils/cpu_test_utils.hpp" using namespace InferenceEngine; using namespace CPUTestUtils; +using namespace ngraph::helpers; using namespace ov::test; namespace CPULayerTestsDefinitions { - -struct SoftMaxConfig { - ov::test::InputShape inputShape; - size_t axis; -}; - -typedef std::tuple - softmaxCPUTestParams; - -class SoftMaxLayerCPUTest : public testing::WithParamInterface, - virtual public SubgraphBaseTest, - public CPUTestsBase { -public: - static std::string getTestCaseName(const testing::TestParamInfo& obj) { - CPUSpecificParams cpuParams; - ElementType inType; - SoftMaxConfig config; - std::string targetDevice; - std::tie(inType, config, targetDevice, cpuParams) = obj.param; - - std::ostringstream result; - result << "netPRC=" << inType << "_"; - result << "IS=" << ov::test::utils::partialShape2str({config.inputShape.first}) << "_"; - result << "TS="; - for (const auto& shape : config.inputShape.second) { - result << "("; - result << ov::test::utils::vec2str(shape); - result << ")_"; - } - result << "axis=" << config.axis << "_"; - result << "trgDev=" << targetDevice; - result << CPUTestsBase::getTestCaseName(cpuParams); - - return result.str(); - } - -protected: - void SetUp() override { - ElementType inType; - SoftMaxConfig config; - CPUSpecificParams cpuParams; - std::tie(inType, config, targetDevice, cpuParams) = this->GetParam(); - - std::tie(inFmts, outFmts, priority, selectedType) = cpuParams; - if (selectedType.empty()) { - selectedType = getPrimitiveType(); - } - - if (inType == ElementType::bf16) { - rel_threshold = 2e-2f; - } - selectedType = makeSelectedTypeStr(selectedType, inType); - init_input_shapes({config.inputShape}); - ov::ParameterVector params; - for (auto&& shape : inputDynamicShapes) { - params.push_back(std::make_shared(inType, shape)); - } - const auto paramOuts = - ngraph::helpers::convert2OutputVector(ngraph::helpers::castOps2Nodes(params)); - - const auto softMax = std::make_shared(paramOuts.at(0), config.axis); - - function = makeNgraphFunction(inType, params, softMax, "SoftMax"); - } -}; - -TEST_P(SoftMaxLayerCPUTest, CompareWithRefs) { - run(); - CheckPluginRelatedResults(compiledModel, "Softmax"); -} - -namespace { -// not optimized cpu spec +namespace SoftMax { const auto notOptimizedCPUSpec = CPUSpecificParams{{}, {}, {"ref_any"}, "ref_any"}; const std::vector optimizedConfigsFP32 = { @@ -222,6 +146,5 @@ INSTANTIATE_TEST_SUITE_P(smoke_SoftMax_Unsupported_CPU, SoftMaxLayerCPUTest, UnsupportedParams, SoftMaxLayerCPUTest::getTestCaseName); - -} // namespace -} // namespace CPULayerTestsDefinitions +} // namespace SoftMax +} // namespace CPULayerTestsDefinitions \ No newline at end of file