From c5886a36da585a4336bddd5ae123141859436b04 Mon Sep 17 00:00:00 2001 From: Sofya Balandina Date: Thu, 21 Mar 2024 21:16:50 +0000 Subject: [PATCH] [IE TESTS][OP CONFORMANCE] Move `ConstRanges` range calculation to `InGenData` constructor (#23427) ### Details: - *Move static const range initialization to `InData` structure* ### Tickets: - *[125993](https://jira.devtools.intel.com/browse/CVS-125993)* --- .../src/read_ir/read_ir.cpp | 4 +-- .../base/utils/generate_inputs.hpp | 3 -- .../src/base/utils/generate_inputs.cpp | 28 ---------------- .../common_test_utils/ov_tensor_utils.hpp | 32 ++++++++++++++++++- .../common_test_utils/src/ov_tensor_utils.cpp | 5 +++ 5 files changed, 38 insertions(+), 34 deletions(-) diff --git a/src/tests/functional/plugin/conformance/test_runner/op_conformance_runner/src/read_ir/read_ir.cpp b/src/tests/functional/plugin/conformance/test_runner/op_conformance_runner/src/read_ir/read_ir.cpp index 1943db27f9285f..c9cffe7c8139c8 100644 --- a/src/tests/functional/plugin/conformance/test_runner/op_conformance_runner/src/read_ir/read_ir.cpp +++ b/src/tests/functional/plugin/conformance/test_runner/op_conformance_runner/src/read_ir/read_ir.cpp @@ -139,7 +139,7 @@ void ReadIRTest::SetUp() { if (!in_info.is_const) { continue; } - ov::test::utils::set_const_ranges(in_info.ranges.min, in_info.ranges.max); + utils::ConstRanges::set(in_info.ranges.min, in_info.ranges.max); // auto next_node = param->get_default_output().get_node_shared_ptr(); auto next_node = param->get_default_output().get_target_inputs().begin()->get_node()->shared_from_this(); auto it = inputMap.find(next_node->get_type_info()); @@ -148,7 +148,7 @@ void ReadIRTest::SetUp() { const_node->set_friendly_name(param->get_friendly_name()); ov::replace_node(param, const_node); parameter_to_remove.push_back(param); - ov::test::utils::reset_const_ranges(); + utils::ConstRanges::reset(); } for (const auto& param : parameter_to_remove) { function->remove_parameter(param); diff --git a/src/tests/functional/shared_test_classes/include/shared_test_classes/base/utils/generate_inputs.hpp b/src/tests/functional/shared_test_classes/include/shared_test_classes/base/utils/generate_inputs.hpp index 6e1af8f967a6b8..ff1e4fd2fb000b 100644 --- a/src/tests/functional/shared_test_classes/include/shared_test_classes/base/utils/generate_inputs.hpp +++ b/src/tests/functional/shared_test_classes/include/shared_test_classes/base/utils/generate_inputs.hpp @@ -12,9 +12,6 @@ namespace ov { namespace test { namespace utils { -void set_const_ranges(double _min, double _max); -void reset_const_ranges(); - std::vector color_test_image(size_t height, size_t width, int b_step, ov::preprocess::ColorFormat format); using InputsMap = std::map color_test_image(size_t height, size_t width, int b_step, ov::preprocess::ColorFormat format) { // Test all possible r/g/b values within dimensions int b_dim = 255 / b_step + 1; @@ -113,16 +95,6 @@ ov::Tensor generate(const std::shared_ptr& node, const ov::Shape& targetShape) { InputGenerateData inGenData; - if (const_range.is_defined) { - auto min_orig = inGenData.start_from; - auto max_orig = inGenData.start_from + inGenData.range * inGenData.resolution; - auto min_ref = const_range.min; - auto max_ref = const_range.max; - if (min_orig < min_ref || min_orig == 0) - inGenData.start_from = min_ref; - inGenData.range = (max_orig > max_ref || max_orig == 10 ? max_ref : max_orig - inGenData.start_from) - inGenData.start_from; - } - if (elemType.is_real()) { set_real_number_generation_data(inGenData); } diff --git a/src/tests/test_utils/common_test_utils/include/common_test_utils/ov_tensor_utils.hpp b/src/tests/test_utils/common_test_utils/include/common_test_utils/ov_tensor_utils.hpp index aa36a4ab140b41..2b6da6fe54a776 100644 --- a/src/tests/test_utils/common_test_utils/include/common_test_utils/ov_tensor_utils.hpp +++ b/src/tests/test_utils/common_test_utils/include/common_test_utils/ov_tensor_utils.hpp @@ -9,6 +9,25 @@ namespace ov { namespace test { namespace utils { + +// todo: remove w/a to generate correct constant data (replace parameter to const) in conformance with defined range +struct ConstRanges { + static double max, min; + static bool is_defined; + + static void set(double _min, double _max) { + min = _min; + max = _max; + is_defined = true; + } + + static void reset() { + min = std::numeric_limits::max(); + max = std::numeric_limits::min(); + is_defined = false; + } +}; + struct InputGenerateData { double start_from = 0; uint32_t range = 10; @@ -19,7 +38,18 @@ struct InputGenerateData { : start_from(_start_from), range(_range), resolution(_resolution), - seed(_seed){}; + seed(_seed) { + if (ConstRanges::is_defined) { + auto min_orig = start_from; + auto max_orig = start_from + range * resolution; + auto min_ref = ConstRanges::min; + auto max_ref = ConstRanges::max; + if (min_orig < min_ref || min_orig == 0) + start_from = min_ref; + range = + (uint32_t)round((max_orig > max_ref || max_orig == 10 ? max_ref : max_orig - start_from) - start_from); + } + }; }; ov::Tensor create_and_fill_tensor(const ov::element::Type element_type, diff --git a/src/tests/test_utils/common_test_utils/src/ov_tensor_utils.cpp b/src/tests/test_utils/common_test_utils/src/ov_tensor_utils.cpp index 435dbf63257efd..78bf8e02810874 100644 --- a/src/tests/test_utils/common_test_utils/src/ov_tensor_utils.cpp +++ b/src/tests/test_utils/common_test_utils/src/ov_tensor_utils.cpp @@ -12,6 +12,11 @@ namespace ov { namespace test { namespace utils { + +double ConstRanges::max = std::numeric_limits::min(); +double ConstRanges::min = std::numeric_limits::max(); +bool ConstRanges::is_defined = false; + ov::Tensor create_and_fill_tensor(const ov::element::Type element_type, const ov::Shape& shape, const InputGenerateData& inGenData) {