test_arange.py 3.4 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 paddle
16
from paddle.fluid import core
17
from paddle.static import program_guard, Program
18 19 20 21 22 23 24 25 26 27 28 29
import unittest
import numpy as np
from op_test import OpTest


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),
30
            'Step': np.array([self.case[2]]).astype(self.dtype),
31 32 33
        }

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

    def init_config(self):
        self.dtype = np.float32
        self.case = (0, 1, 0.2)

    def test_check_output(self):
        self.check_output()


47
class TestFloatArangeOp(TestArangeOp):
48 49 50 51 52
    def init_config(self):
        self.dtype = np.float32
        self.case = (0, 5, 1)


53
class TestInt32ArangeOp(TestArangeOp):
54 55 56 57 58
    def init_config(self):
        self.dtype = np.int32
        self.case = (0, 5, 2)


59
class TestFloat64ArangeOp(TestArangeOp):
60
    def init_config(self):
61
        self.dtype = np.float64
62 63 64
        self.case = (10, 1, -2)


65
class TestInt64ArangeOp(TestArangeOp):
66
    def init_config(self):
67
        self.dtype = np.int64
68 69 70
        self.case = (-1, -10, -2)


71 72 73 74 75 76
class TestArangeOpError(unittest.TestCase):
    def test_errors(self):
        with program_guard(Program(), Program()):
            self.assertRaises(TypeError, paddle.arange, 10, dtype='int8')


77 78
class TestArangeAPI(unittest.TestCase):
    def test_out(self):
79 80 81
        with program_guard(Program(), Program()):
            x1 = paddle.arange(0, 5, 1, 'float32')

82 83 84 85 86
            place = (
                paddle.CUDAPlace(0)
                if core.is_compiled_with_cuda()
                else paddle.CPUPlace()
            )
87
            exe = paddle.static.Executor(place)
88 89 90 91 92 93 94 95
            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):
96 97 98 99 100
        place = (
            paddle.CUDAPlace(0)
            if core.is_compiled_with_cuda()
            else paddle.CPUPlace()
        )
101 102 103 104 105
        paddle.disable_static(place)
        x1 = paddle.arange(0, 5, 1)
        x2 = paddle.tensor.arange(5)
        x3 = paddle.tensor.creation.arange(5)

Z
Zhou Wei 已提交
106 107 108
        start = paddle.to_tensor(np.array([0], 'float32'))
        end = paddle.to_tensor(np.array([5], 'float32'))
        step = paddle.to_tensor(np.array([1], 'float32'))
109 110
        x4 = paddle.arange(start, end, step, 'int64')
        paddle.enable_static()
111 112 113 114

        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)
115 116 117 118


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