//***************************************************************************** // Copyright 2017-2019 Intel Corporation // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. //***************************************************************************** #include "gtest/gtest.h" #include "ngraph/ngraph.hpp" #include "util/all_close.hpp" #include "util/all_close_f.hpp" #include "util/known_element_types.hpp" #include "util/ndarray.hpp" #include "util/test_control.hpp" #include "util/test_tools.hpp" using namespace std; using namespace ngraph; static string s_manifest = "${MANIFEST}"; template <typename OP> void make_unary_empty_test(const string& backend_name) { Shape shape{0}; ParameterVector params; NodeVector result_list; for (size_t i = 0; i < s_known_element_types.size(); i++) { shared_ptr<op::Parameter> p = make_shared<op::Parameter>(s_known_element_types[i], shape); params.push_back(p); result_list.push_back(make_shared<OP>(p)); } auto f = make_shared<Function>(result_list, params); auto backend = runtime::Backend::create(backend_name); vector<shared_ptr<runtime::Tensor>> inputs; vector<shared_ptr<runtime::Tensor>> outputs; for (size_t i = 0; i < s_known_element_types.size(); i++) { inputs.push_back(backend->create_tensor(s_known_element_types[i], shape)); outputs.push_back(backend->create_tensor(s_known_element_types[i], shape)); } auto handle = backend->compile(f); handle->call_with_validate(outputs, inputs); EXPECT_EQ(read_vector<float>(inputs[0]).size(), 0); EXPECT_EQ(read_vector<double>(inputs[1]).size(), 0); EXPECT_EQ(read_vector<int8_t>(inputs[2]).size(), 0); EXPECT_EQ(read_vector<int16_t>(inputs[3]).size(), 0); EXPECT_EQ(read_vector<int32_t>(inputs[4]).size(), 0); EXPECT_EQ(read_vector<int64_t>(inputs[5]).size(), 0); EXPECT_EQ(read_vector<uint8_t>(inputs[6]).size(), 0); EXPECT_EQ(read_vector<uint16_t>(inputs[7]).size(), 0); EXPECT_EQ(read_vector<uint32_t>(inputs[8]).size(), 0); EXPECT_EQ(read_vector<uint64_t>(inputs[9]).size(), 0); EXPECT_EQ(read_vector<float>(outputs[0]).size(), 0); EXPECT_EQ(read_vector<double>(outputs[1]).size(), 0); EXPECT_EQ(read_vector<int8_t>(outputs[2]).size(), 0); EXPECT_EQ(read_vector<int16_t>(outputs[3]).size(), 0); EXPECT_EQ(read_vector<int32_t>(outputs[4]).size(), 0); EXPECT_EQ(read_vector<int64_t>(outputs[5]).size(), 0); EXPECT_EQ(read_vector<uint8_t>(outputs[6]).size(), 0); EXPECT_EQ(read_vector<uint16_t>(outputs[7]).size(), 0); EXPECT_EQ(read_vector<uint32_t>(outputs[8]).size(), 0); EXPECT_EQ(read_vector<uint64_t>(outputs[9]).size(), 0); } template <typename OP> void make_binary_empty_test(const string& backend_name, bool is_comparison = false) { Shape shape{0}; ParameterVector A; for (size_t i = 0; i < s_known_element_types.size(); i++) { A.push_back(make_shared<op::Parameter>(s_known_element_types[i], shape)); } NodeVector result_list; for (shared_ptr<op::Parameter> p : A) { result_list.push_back(make_shared<OP>(p, p)); } auto f = make_shared<Function>(result_list, A); auto backend = runtime::Backend::create(backend_name); vector<shared_ptr<runtime::Tensor>> inputs; vector<shared_ptr<runtime::Tensor>> outputs; for (size_t i = 0; i < s_known_element_types.size(); i++) { inputs.push_back(backend->create_tensor(s_known_element_types[i], shape)); if (is_comparison) { outputs.push_back(backend->create_tensor(element::from<char>(), shape)); } else { outputs.push_back(backend->create_tensor(s_known_element_types[i], shape)); } } auto handle = backend->compile(f); handle->call_with_validate(outputs, inputs); EXPECT_EQ(read_vector<float>(inputs[0]).size(), 0); EXPECT_EQ(read_vector<double>(inputs[1]).size(), 0); EXPECT_EQ(read_vector<int8_t>(inputs[2]).size(), 0); EXPECT_EQ(read_vector<int16_t>(inputs[3]).size(), 0); EXPECT_EQ(read_vector<int32_t>(inputs[4]).size(), 0); EXPECT_EQ(read_vector<int64_t>(inputs[5]).size(), 0); EXPECT_EQ(read_vector<uint8_t>(inputs[6]).size(), 0); EXPECT_EQ(read_vector<uint16_t>(inputs[7]).size(), 0); EXPECT_EQ(read_vector<uint32_t>(inputs[8]).size(), 0); EXPECT_EQ(read_vector<uint64_t>(inputs[9]).size(), 0); if (is_comparison) { EXPECT_EQ(read_vector<char>(outputs[0]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[1]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[2]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[3]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[4]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[5]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[6]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[7]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[8]).size(), 0); EXPECT_EQ(read_vector<char>(outputs[9]).size(), 0); } else { EXPECT_EQ(read_vector<float>(outputs[0]).size(), 0); EXPECT_EQ(read_vector<double>(outputs[1]).size(), 0); EXPECT_EQ(read_vector<int8_t>(outputs[2]).size(), 0); EXPECT_EQ(read_vector<int16_t>(outputs[3]).size(), 0); EXPECT_EQ(read_vector<int32_t>(outputs[4]).size(), 0); EXPECT_EQ(read_vector<int64_t>(outputs[5]).size(), 0); EXPECT_EQ(read_vector<uint8_t>(outputs[6]).size(), 0); EXPECT_EQ(read_vector<uint16_t>(outputs[7]).size(), 0); EXPECT_EQ(read_vector<uint32_t>(outputs[8]).size(), 0); EXPECT_EQ(read_vector<uint64_t>(outputs[9]).size(), 0); } } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_abs) { make_unary_empty_test<op::Abs>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_ceiling) { make_unary_empty_test<op::Ceiling>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_erf) { make_unary_empty_test<op::Erf>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_exp) { make_unary_empty_test<op::Exp>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_floor) { make_unary_empty_test<op::Floor>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_log) { make_unary_empty_test<op::Log>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_negative) { make_unary_empty_test<op::Negative>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_not) { Shape shape{0}; auto A = make_shared<op::Parameter>(element::from<char>(), shape); auto f = make_shared<Function>(make_shared<op::Not>(A), ParameterVector{A}); auto backend = runtime::Backend::create("${BACKEND_NAME}"); auto a = backend->create_tensor(element::from<char>(), shape); auto result = backend->create_tensor(element::from<char>(), shape); auto handle = backend->compile(f); handle->call_with_validate({result}, {a}); auto in_vec = read_vector<char>(a); auto out_vec = read_vector<char>(result); EXPECT_EQ(in_vec.size(), 0); EXPECT_EQ(out_vec.size(), 0); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_sign) { make_unary_empty_test<op::Sign>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_sqrt) { make_unary_empty_test<op::Sqrt>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_sin) { make_unary_empty_test<op::Sin>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_sinh) { make_unary_empty_test<op::Sinh>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_cos) { make_unary_empty_test<op::Cos>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_cosh) { make_unary_empty_test<op::Cosh>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_tan) { make_unary_empty_test<op::Tan>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_tanh) { make_unary_empty_test<op::Tanh>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_asin) { make_unary_empty_test<op::Asin>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_acos) { make_unary_empty_test<op::Acos>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_atan) { make_unary_empty_test<op::Atan>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_add) { make_binary_empty_test<op::Add>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_divide) { make_binary_empty_test<op::Divide>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_eq) { make_binary_empty_test<op::Equal>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_greater) { make_binary_empty_test<op::Greater>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_greatereq) { make_binary_empty_test<op::GreaterEq>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_less) { make_binary_empty_test<op::Less>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_lesseq) { make_binary_empty_test<op::LessEq>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_maximum) { make_binary_empty_test<op::Maximum>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_minimum) { make_binary_empty_test<op::Minimum>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_multiply) { make_binary_empty_test<op::Multiply>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_not_equal) { make_binary_empty_test<op::NotEqual>("${BACKEND_NAME}", true); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_power) { make_binary_empty_test<op::Power>("${BACKEND_NAME}"); } NGRAPH_TEST(${BACKEND_NAME}, zero_sized_subtract) { make_binary_empty_test<op::Subtract>("${BACKEND_NAME}"); }