test_arange.py 5.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
#   Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
#
# 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 unittest
16

17
import numpy as np
18
from eager_op_test import OpTest, convert_float_to_uint16
19

20 21 22 23
import paddle
from paddle.fluid import core
from paddle.static import Program, program_guard

24

姜永久 已提交
25 26 27 28
def arange_wrapper(start, end, step, dtype="float32"):
    return paddle.arange(start, end, step, dtype)


29 30 31 32 33 34 35
class TestArangeOp(OpTest):
    def setUp(self):
        self.op_type = "range"
        self.init_config()
        self.inputs = {
            'Start': np.array([self.case[0]]).astype(self.dtype),
            'End': np.array([self.case[1]]).astype(self.dtype),
36
            'Step': np.array([self.case[2]]).astype(self.dtype),
37 38 39
        }

        self.outputs = {
40 41 42
            'Out': np.arange(self.case[0], self.case[1], self.case[2]).astype(
                self.dtype
            )
43 44 45 46
        }

    def init_config(self):
        self.dtype = np.float32
姜永久 已提交
47
        self.python_api = arange_wrapper
48 49 50 51 52 53
        self.case = (0, 1, 0.2)

    def test_check_output(self):
        self.check_output()


54
class TestFloatArangeOp(TestArangeOp):
55 56
    def init_config(self):
        self.dtype = np.float32
姜永久 已提交
57
        self.python_api = paddle.arange
58 59 60
        self.case = (0, 5, 1)


61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
class TestFloa16ArangeOp(TestArangeOp):
    def init_config(self):
        self.dtype = np.float16
        self.python_api = paddle.arange
        self.case = (0, 5, 1)

    def test_check_output(self):
        self.check_output()


@unittest.skipIf(
    not core.is_compiled_with_cuda()
    or not core.is_bfloat16_supported(core.CUDAPlace(0)),
    "core is not complied with CUDA and not support the bfloat16",
)
class TestBFloat16ArangeOp(OpTest):
    def setUp(self):
        self.op_type = "range"
        self.init_config()
        self.inputs = {
            'Start': convert_float_to_uint16(self.start),
            'End': convert_float_to_uint16(self.end),
            'Step': convert_float_to_uint16(self.step),
        }

        self.outputs = {
            'Out': convert_float_to_uint16(
                np.arange(self.start, self.end, self.step)
            )
        }

    def init_config(self):
        self.dtype = np.uint16
        self.python_api = arange_wrapper
        self.case = (0, 5, 1)
        self.start = np.array([self.case[0]]).astype(np.float32)
        self.end = np.array([self.case[1]]).astype(np.float32)
        self.step = np.array([self.case[2]]).astype(np.float32)

    def test_check_output(self):
        place = core.CUDAPlace(0)
        self.check_output_with_place(place)


105
class TestInt32ArangeOp(TestArangeOp):
106 107
    def init_config(self):
        self.dtype = np.int32
姜永久 已提交
108
        self.python_api = paddle.arange
109 110 111
        self.case = (0, 5, 2)


112
class TestFloat64ArangeOp(TestArangeOp):
113
    def init_config(self):
114
        self.dtype = np.float64
姜永久 已提交
115
        self.python_api = paddle.arange
116 117 118
        self.case = (10, 1, -2)


119
class TestInt64ArangeOp(TestArangeOp):
120
    def init_config(self):
121
        self.dtype = np.int64
姜永久 已提交
122
        self.python_api = paddle.arange
123 124 125
        self.case = (-1, -10, -2)


Y
Yuanle Liu 已提交
126 127 128
class TestZeroSizeArangeOp(TestArangeOp):
    def init_config(self):
        self.dtype = np.int32
姜永久 已提交
129
        self.python_api = paddle.arange
Y
Yuanle Liu 已提交
130 131 132
        self.case = (0, 0, 1)


133 134 135 136 137 138
class TestArangeOpError(unittest.TestCase):
    def test_errors(self):
        with program_guard(Program(), Program()):
            self.assertRaises(TypeError, paddle.arange, 10, dtype='int8')


139 140
class TestArangeAPI(unittest.TestCase):
    def test_out(self):
141 142 143
        with program_guard(Program(), Program()):
            x1 = paddle.arange(0, 5, 1, 'float32')

144 145 146 147 148
            place = (
                paddle.CUDAPlace(0)
                if core.is_compiled_with_cuda()
                else paddle.CPUPlace()
            )
149
            exe = paddle.static.Executor(place)
150 151 152 153 154 155 156 157
            out = exe.run(fetch_list=[x1])

        expected_data = np.arange(0, 5, 1).astype(np.float32)
        self.assertEqual((out == expected_data).all(), True)


class TestArangeImperative(unittest.TestCase):
    def test_out(self):
158 159 160 161 162
        place = (
            paddle.CUDAPlace(0)
            if core.is_compiled_with_cuda()
            else paddle.CPUPlace()
        )
163 164 165 166 167
        paddle.disable_static(place)
        x1 = paddle.arange(0, 5, 1)
        x2 = paddle.tensor.arange(5)
        x3 = paddle.tensor.creation.arange(5)

Z
Zhou Wei 已提交
168 169 170
        start = paddle.to_tensor(np.array([0], 'float32'))
        end = paddle.to_tensor(np.array([5], 'float32'))
        step = paddle.to_tensor(np.array([1], 'float32'))
171 172
        x4 = paddle.arange(start, end, step, 'int64')
        paddle.enable_static()
173 174 175 176

        expected_data = np.arange(0, 5, 1).astype(np.int64)
        for i in [x1, x2, x3, x4]:
            self.assertEqual((i.numpy() == expected_data).all(), True)
177 178 179 180


if __name__ == "__main__":
    unittest.main()