// Copyright (C) 2018-2021 Intel Corporation // SPDX-License-Identifier: Apache-2.0 // #include #include #include #include #include #include "gmock/gmock.h" #include "gtest/gtest.h" #include "ngraph/graph_util.hpp" #include "ngraph/ngraph.hpp" #include "ngraph/opsets/opset.hpp" #include "ngraph/variant.hpp" NGRAPH_SUPPRESS_DEPRECATED_START using namespace std; using namespace ngraph; TEST(op, is_op) { auto arg0 = make_shared(element::f32, Shape{1}); ASSERT_NE(nullptr, arg0); EXPECT_TRUE(op::is_parameter(arg0)); } TEST(op, is_parameter) { auto arg0 = make_shared(element::f32, Shape{1}); ASSERT_NE(nullptr, arg0); auto t0 = make_shared(arg0, arg0); ASSERT_NE(nullptr, t0); EXPECT_FALSE(op::is_parameter(t0)); } TEST(op, provenance_tag) { auto node = make_shared(element::f32, Shape{1}); auto tag1 = "parameter node"; auto tag2 = "f32 node"; node->add_provenance_tag(tag1); node->add_provenance_tag(tag2); node->remove_provenance_tag(tag1); auto tags = node->get_provenance_tags(); ASSERT_TRUE(tags.find(tag1) == tags.end()); ASSERT_TRUE(tags.find(tag2) != tags.end()); } TEST(op, opset_multi_thread) { auto doTest = [&](std::function fun) { std::atomic opset{nullptr}; std::atomic_bool failed{false}; auto threadFun = [&]() { const ngraph::OpSet* op = &fun(); const ngraph::OpSet* current = opset; do { if (current != nullptr && current != op) { failed = true; break; } } while (opset.compare_exchange_strong(op, current)); }; std::thread t1{threadFun}; std::thread t2{threadFun}; t1.join(); t2.join(); ASSERT_FALSE(failed); }; doTest(ngraph::get_opset1); doTest(ngraph::get_opset2); doTest(ngraph::get_opset3); doTest(ngraph::get_opset4); doTest(ngraph::get_opset5); doTest(ngraph::get_opset6); doTest(ngraph::get_opset7); } struct Ship { std::string name; int16_t x; int16_t y; }; namespace ov { template <> class VariantWrapper : public VariantImpl { public: static constexpr VariantTypeInfo type_info{"Variant::Ship", 0}; const VariantTypeInfo& get_type_info() const override { return type_info; } VariantWrapper(const value_type& value) : VariantImpl(value) {} }; constexpr VariantTypeInfo VariantWrapper::type_info; } // namespace ov TEST(op, variant) { shared_ptr var_std_string = make_variant("My string"); ASSERT_TRUE((ov::is_type>(var_std_string))); EXPECT_EQ((ov::as_type_ptr>(var_std_string)->get()), "My string"); shared_ptr var_int64_t = make_variant(27); ASSERT_TRUE((ov::is_type>(var_int64_t))); EXPECT_FALSE((ov::is_type>(var_int64_t))); EXPECT_EQ((ov::as_type_ptr>(var_int64_t)->get()), 27); shared_ptr var_ship = make_variant(Ship{"Lollipop", 3, 4}); ASSERT_TRUE((ov::is_type>(var_ship))); Ship& ship = ov::as_type_ptr>(var_ship)->get(); EXPECT_EQ(ship.name, "Lollipop"); EXPECT_EQ(ship.x, 3); EXPECT_EQ(ship.y, 4); auto node = make_shared(element::f32, Shape{1}); // Check Node RTInfo node->get_rt_info()["A"] = var_ship; auto node_var_ship = node->get_rt_info().at("A"); ASSERT_TRUE((ov::is_type>(node_var_ship))); Ship& node_ship = ov::as_type_ptr>(node_var_ship)->get(); EXPECT_EQ(&node_ship, &ship); // Check Node Input RTInfo auto relu = make_shared(node); relu->input(0).get_rt_info()["A"] = var_ship; auto node_input_var_ship = node->get_rt_info().at("A"); ASSERT_TRUE((ov::is_type>(node_input_var_ship))); Ship& node_input_ship = ov::as_type_ptr>(node_input_var_ship)->get(); EXPECT_EQ(&node_input_ship, &ship); // Check Node Input RTInfo node->output(0).get_rt_info()["A"] = var_ship; auto node_output_var_ship = node->get_rt_info().at("A"); ASSERT_TRUE((ov::is_type>(node_output_var_ship))); Ship& node_output_ship = ov::as_type_ptr>(node_input_var_ship)->get(); EXPECT_EQ(&node_output_ship, &ship); }