* Moved FrameworkNode to nGraph * Moved graph comparator to ngraph test util * Fixed build * Try to fix centos * Fix export target * Moved engine utils to separate library * Removed ONNX util from common library * Fixed build * Fixed code style
83 lines
3.2 KiB
C++
83 lines
3.2 KiB
C++
// Copyright (C) 2018-2021 Intel Corporation
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
//
|
|
|
|
#include "engines_util/execute_tools.hpp"
|
|
#include "engines_util/random.hpp"
|
|
#include "gtest/gtest.h"
|
|
#include "ngraph/ngraph.hpp"
|
|
#include "ngraph/runtime/tensor.hpp"
|
|
#include "runtime/backend.hpp"
|
|
#include "util/all_close_f.hpp"
|
|
#include "util/ndarray.hpp"
|
|
#include "util/test_control.hpp"
|
|
|
|
using namespace std;
|
|
using namespace ngraph;
|
|
|
|
static string s_manifest = "${MANIFEST}";
|
|
|
|
// This tests a backend's implementation of the two parameter version of create_tensor
|
|
NGRAPH_TEST(${BACKEND_NAME}, create_tensor_1) {
|
|
Shape shape{2, 2};
|
|
auto A = make_shared<op::Parameter>(element::f32, shape);
|
|
auto B = make_shared<op::Parameter>(element::f32, shape);
|
|
auto f = make_shared<Function>(make_shared<op::v1::Add>(A, B), ParameterVector{A, B});
|
|
|
|
auto backend = runtime::Backend::create("${BACKEND_NAME}");
|
|
|
|
// Create some tensors for input/output
|
|
vector<float> av = {1, 2, 3, 4};
|
|
vector<float> bv = {5, 6, 7, 8};
|
|
shared_ptr<runtime::Tensor> a = backend->create_tensor(element::f32, shape);
|
|
shared_ptr<runtime::Tensor> b = backend->create_tensor(element::f32, shape);
|
|
copy_data(a, av);
|
|
copy_data(b, bv);
|
|
|
|
shared_ptr<runtime::Tensor> result = backend->create_tensor(element::f32, shape);
|
|
|
|
auto handle = backend->compile(f);
|
|
handle->call_with_validate({result}, {a, b});
|
|
vector<float> expected = {6, 8, 10, 12};
|
|
EXPECT_TRUE(test::all_close_f(read_vector<float>(result), expected, MIN_FLOAT_TOLERANCE_BITS));
|
|
}
|
|
|
|
NGRAPH_TEST(${BACKEND_NAME}, get_parameters_and_results) {
|
|
Shape shape{2, 2};
|
|
auto A = make_shared<op::Parameter>(element::f32, shape);
|
|
auto B = make_shared<op::Parameter>(element::f32, shape);
|
|
auto C = make_shared<op::Parameter>(element::f32, shape);
|
|
auto arg = make_shared<op::v1::Multiply>(make_shared<op::v1::Add>(A, B), C);
|
|
auto f = make_shared<Function>(arg, ParameterVector{A, B, C});
|
|
|
|
auto backend = runtime::Backend::create("${BACKEND_NAME}");
|
|
|
|
// Create some tensors for input/output
|
|
shared_ptr<runtime::Tensor> a = backend->create_tensor(element::f32, shape);
|
|
shared_ptr<runtime::Tensor> b = backend->create_tensor(element::f32, shape);
|
|
shared_ptr<runtime::Tensor> c = backend->create_tensor(element::f32, shape);
|
|
shared_ptr<runtime::Tensor> result = backend->create_tensor(element::f32, shape);
|
|
|
|
copy_data(a, test::NDArray<float, 2>({{1, 2}, {3, 4}}).get_vector());
|
|
copy_data(b, test::NDArray<float, 2>({{5, 6}, {7, 8}}).get_vector());
|
|
copy_data(c, test::NDArray<float, 2>({{9, 10}, {11, 12}}).get_vector());
|
|
|
|
auto handle = backend->compile(f);
|
|
auto parameters = handle->get_parameters();
|
|
auto results = handle->get_results();
|
|
ASSERT_EQ(parameters.size(), 3);
|
|
ASSERT_EQ(results.size(), 1);
|
|
|
|
// This part can't be enabled until we force backends to make a copy of the source graph
|
|
// auto func_parameters = f->get_parameters();
|
|
// auto func_results = f->get_results();
|
|
// for (size_t i = 0; i < 3; ++i)
|
|
// {
|
|
// EXPECT_NE(parameters[i], func_parameters[i]);
|
|
// }
|
|
// for (size_t i = 0; i < 1; ++i)
|
|
// {
|
|
// EXPECT_NE(results[i], func_results[i]);
|
|
// }
|
|
}
|