mindspore/tests/st/ops/test_split.py

405 lines
13 KiB
Python
Raw Normal View History

2022-11-22 14:40:11 +08:00
# Copyright 2022 Huawei Technologies Co., Ltd
#
# 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.
# ============================================================================
import numpy as np
import pytest
import mindspore as ms
import mindspore.nn as nn
import mindspore.ops as ops
2022-11-22 14:40:11 +08:00
class TensorSplitNet(nn.Cell):
2022-11-22 14:40:11 +08:00
def construct(self, x, indices_or_sections, axis=0):
out = ops.tensor_split(x, indices_or_sections, axis)
return out
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_int(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when the type of `indices_or_sections` is int.
Expectation: success
"""
ms.set_context(mode=mode)
2022-11-22 14:40:11 +08:00
net = TensorSplitNet()
2022-11-22 14:40:11 +08:00
a = np.array(np.arange(20).reshape((10, 2)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = 3
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_list(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when the type of `indices_or_sections` is tuple(int) or tuple(int).
Expectation: success
"""
ms.set_context(mode=mode)
2022-11-22 14:40:11 +08:00
net = TensorSplitNet()
2022-11-22 14:40:11 +08:00
a = np.array(np.arange(10).reshape((5, 2)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = [2, 4]
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
2022-11-22 14:40:11 +08:00
@pytest.mark.level1
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_list2(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when `indices_or_sections` is out of normal length.
Expectation: success
"""
ms.set_context(mode=mode)
a = np.arange(10).reshape((5, 2))
indices_or_sections = [1, 4, 7]
net = TensorSplitNet()
x = ms.Tensor(a, dtype=ms.int64)
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level1
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_list3(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when `indices_or_sections` has negative.
Expectation: success
"""
ms.set_context(mode=mode)
a = np.arange(10).reshape((5, 2))
indices_or_sections = [-5, 4, 3, 7]
net = TensorSplitNet()
x = ms.Tensor(a, dtype=ms.int64)
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level1
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_list4(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when `indices_or_sections` has negative number and out of range.
Expectation: success
"""
ms.set_context(mode=mode)
a = np.arange(12)
indices_or_sections = [-18, -14, -10]
net = TensorSplitNet()
x = ms.Tensor(a, dtype=ms.int64)
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level1
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_tensor_split_list5(mode):
"""
Feature: tensor_split
Description: Verify the result of tensor_split when `indices_or_sections` has special order.
Expectation: success
"""
ms.set_context(mode=mode)
a = np.arange(12)
indices_or_sections = [-18, -10, -14, 2]
net = TensorSplitNet()
x = ms.Tensor(a, dtype=ms.int64)
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
2022-11-22 14:40:11 +08:00
class VSplitNet(nn.Cell):
def construct(self, x, indices_or_sections):
out = ops.vsplit(x, indices_or_sections)
return out
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_vsplit_int(mode):
"""
Feature: vsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is int.
Expectation: success
"""
ms.set_context(mode=mode)
net = VSplitNet()
a = np.arange(20).reshape((10, 2))
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = 3
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=0)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_vsplit_list(mode):
"""
Feature: vsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is tuple(int) or tuple(int).
Expectation: success
"""
ms.set_context(mode=mode)
net = VSplitNet()
a = np.array(np.arange(10).reshape((5, 2)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = [2, 4]
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=0)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
class HSplitNet(nn.Cell):
def construct(self, x, indices_or_sections):
out = ops.hsplit(x, indices_or_sections)
return out
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_hsplit_int(mode):
"""
Feature: hsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is int.
Expectation: success
"""
ms.set_context(mode=mode)
net = HSplitNet()
2022-11-22 14:40:11 +08:00
a = np.array(np.arange(20).reshape((2, 10)), dtype=np.float32)
2022-11-22 14:40:11 +08:00
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = 3
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=1)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_hsplit_list(mode):
"""
Feature: hsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is tuple(int) or tuple(int).
Expectation: success
"""
ms.set_context(mode=mode)
net = HSplitNet()
a = np.array(np.arange(10).reshape((2, 5)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = [2, 4]
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=1)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
class DSplitNet(nn.Cell):
def construct(self, x, indices_or_sections):
out = ops.dsplit(x, indices_or_sections)
return out
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_dsplit_int(mode):
"""
Feature: dsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is int.
Expectation: success
"""
ms.set_context(mode=mode)
net = DSplitNet()
a = np.array(np.arange(20).reshape((1, 2, 10)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = 3
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=2)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_dsplit_list(mode):
"""
Feature: dsplit
Description: Verify the result of tensor_split when the type of `indices_or_sections` is tuple(int) or tuple(int).
Expectation: success
"""
ms.set_context(mode=mode)
net = DSplitNet()
a = np.array(np.arange(20).reshape((1, 2, 10)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
indices_or_sections = [2, 4]
out = net(x, indices_or_sections)
expect = np.array_split(a, indices_or_sections, axis=2)
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
2022-11-22 14:40:11 +08:00
class SplitNet(nn.Cell):
def construct(self, x, split_size_or_sections, axis=0):
out = ops.split(x, split_size_or_sections, axis)
return out
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_split_int(mode):
"""
Feature: split
Description: Verify the result of split.
Expectation: success
"""
ms.set_context(mode=mode)
net = SplitNet()
a = np.array(np.arange(20).reshape((10, 2)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
split_size_or_sections = 5
out = net(x, split_size_or_sections)
expect = [np.array(np.arange(10).reshape((5, 2)), dtype=np.float32),
np.array(np.arange(10, 20).reshape((5, 2)), dtype=np.float32)]
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)
@pytest.mark.level0
@pytest.mark.platform_x86_cpu
@pytest.mark.platform_arm_cpu
@pytest.mark.platform_x86_gpu_training
@pytest.mark.platform_arm_ascend_training
@pytest.mark.platform_x86_ascend_training
@pytest.mark.env_onecard
@pytest.mark.parametrize('mode', [ms.GRAPH_MODE, ms.PYNATIVE_MODE])
def test_f_split_list(mode):
"""
Feature: split
Description: Verify the result of split.
Expectation: success
"""
ms.set_context(mode=mode)
net = SplitNet()
a = np.array(np.arange(20).reshape((2, 10)), dtype=np.float32)
x = ms.Tensor(a, dtype=ms.float32)
split_size_or_sections = [2, 3, 5]
out = net(x, split_size_or_sections, axis=1)
expect = [np.array([[0, 1], [10, 11]], dtype=np.float32),
np.array([[2, 3, 4], [12, 13, 14]], dtype=np.float32),
np.array([[5, 6, 7, 8, 9], [15, 16, 17, 18, 19]], dtype=np.float32)]
for res, exp in zip(out, expect):
assert np.allclose(res.asnumpy(), exp)