test_arange.py 3.4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
#   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.

from __future__ import print_function

import paddle
18
from paddle.fluid import core
19
from paddle.static import program_guard, Program
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
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),
            'Step': np.array([self.case[2]]).astype(self.dtype)
        }

        self.outputs = {
            'Out': np.arange(self.case[0], self.case[1],
                             self.case[2]).astype(self.dtype)
        }

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

    def test_check_output(self):
        self.check_output()


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


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


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


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


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


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

            place = paddle.CUDAPlace(0) if core.is_compiled_with_cuda(
            ) else paddle.CPUPlace()
85
            exe = paddle.static.Executor(place)
86 87 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):
        place = paddle.CUDAPlace(0) if core.is_compiled_with_cuda(
        ) else paddle.CPUPlace()
96 97 98 99 100
        paddle.disable_static(place)
        x1 = paddle.arange(0, 5, 1)
        x2 = paddle.tensor.arange(5)
        x3 = paddle.tensor.creation.arange(5)

Z
Zhou Wei 已提交
101 102 103
        start = paddle.to_tensor(np.array([0], 'float32'))
        end = paddle.to_tensor(np.array([5], 'float32'))
        step = paddle.to_tensor(np.array([1], 'float32'))
104 105
        x4 = paddle.arange(start, end, step, 'int64')
        paddle.enable_static()
106 107 108 109

        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)
110 111 112 113


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