Unverified Commit 8bde7d80 authored by Adam Procter's avatar Adam Procter Committed by GitHub

Merge pull request #2340 from NervanaSystems/aprocter/coordinate-transform-barely-oob

Fix a CoordinateTransform corner case exposed by ONNX unit tests
parents 5d2a7d1c 777a345d
...@@ -134,7 +134,7 @@ CoordinateTransform::CoordinateTransform(const Shape& source_shape, ...@@ -134,7 +134,7 @@ CoordinateTransform::CoordinateTransform(const Shape& source_shape,
for (size_t i = 0; i < m_n_axes; i++) for (size_t i = 0; i < m_n_axes; i++)
{ {
if (source_start_corner[i] >= padded_upper_bounds[i] && if (source_start_corner[i] >= padded_upper_bounds[i] &&
!(source_start_corner[i] == 0 && source_shape[i] == 0)) source_start_corner[i] != source_shape[i])
{ {
std::stringstream ss; std::stringstream ss;
......
...@@ -1714,6 +1714,28 @@ NGRAPH_TEST(${BACKEND_NAME}, slice_3d_strided_different_strides) ...@@ -1714,6 +1714,28 @@ NGRAPH_TEST(${BACKEND_NAME}, slice_3d_strided_different_strides)
EXPECT_EQ((vector<float>{0, 3, 8, 11, 32, 35, 40, 43}), read_vector<float>(result)); EXPECT_EQ((vector<float>{0, 3, 8, 11, 32, 35, 40, 43}), read_vector<float>(result));
} }
NGRAPH_TEST(${BACKEND_NAME}, slice_3d_start_just_oob)
{
Shape shape_a{20, 10, 5};
auto A = make_shared<op::Parameter>(element::f32, shape_a);
Shape shape_r{20, 0, 5};
auto r =
make_shared<op::Slice>(A, Coordinate{0, 10, 0}, Coordinate{20, 10, 5}, Strides{1, 1, 1});
auto f = make_shared<Function>(r, ParameterVector{A});
auto backend = runtime::Backend::create("${BACKEND_NAME}");
// Create some tensors for input/output
auto a = backend->create_tensor(element::f32, shape_a);
vector<float> a_data(20 * 10 * 5, 222.0f);
copy_data(a, a_data);
auto result = backend->create_tensor(element::f32, shape_r);
auto handle = backend->compile(f);
backend->call_with_validate(handle, {result}, {a});
EXPECT_EQ((vector<float>{}), read_vector<float>(result));
}
NGRAPH_TEST(${BACKEND_NAME}, scalar_constant_float32) NGRAPH_TEST(${BACKEND_NAME}, scalar_constant_float32)
{ {
auto r = op::Constant::create(element::f32, Shape{}, {4.75}); auto r = op::Constant::create(element::f32, Shape{}, {4.75});
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment