test_compare_reduce_op.py 4.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
#   Copyright (c) 2018 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 op_test
import unittest
import numpy as np
import paddle
import paddle.fluid as fluid
from paddle.fluid import Program, program_guard


W
wawltor 已提交
25
def create_test_not_equal_class(op_type, typename, callback):
26

27
    class Cls(op_test.OpTest):
28

29
        def setUp(self):
W
wawltor 已提交
30 31
            x = np.random.random(size=(10, 7)).astype(typename)
            y = np.random.random(size=(10, 7)).astype(typename)
32
            z = callback(x, y)
H
hong 已提交
33
            self.python_api = paddle.tensor.equal_all
34 35 36 37 38
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
H
hong 已提交
39
            self.check_output(check_eager=True)
40

W
wawltor 已提交
41
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'not_equal_all')
42 43 44 45
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


W
wawltor 已提交
46
def create_test_not_shape_equal_class(op_type, typename, callback):
47

48
    class Cls(op_test.OpTest):
49

50 51
        def setUp(self):
            x = np.random.random(size=(10, 7)).astype(typename)
W
wawltor 已提交
52
            y = np.random.random(size=(10)).astype(typename)
53
            z = callback(x, y)
H
hong 已提交
54
            self.python_api = paddle.tensor.equal_all
55 56 57 58 59
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
H
hong 已提交
60
            self.check_output(check_eager=True)
61

W
wawltor 已提交
62
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'not_shape_equal_all')
63 64 65 66 67
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


def create_test_equal_class(op_type, typename, callback):
68

69
    class Cls(op_test.OpTest):
70

71 72 73
        def setUp(self):
            x = y = np.random.random(size=(10, 7)).astype(typename)
            z = callback(x, y)
H
hong 已提交
74
            self.python_api = paddle.tensor.equal_all
75 76 77 78 79
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
H
hong 已提交
80
            self.check_output(check_eager=True)
81

W
wawltor 已提交
82
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'equal_all')
83 84 85 86
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


87
def create_test_dim1_class(op_type, typename, callback):
88

89
    class Cls(op_test.OpTest):
90

91 92 93 94 95
        def setUp(self):
            x = y = np.random.random(size=(1)).astype(typename)
            x = np.array([True, False, True]).astype(typename)
            x = np.array([False, False, True]).astype(typename)
            z = callback(x, y)
H
hong 已提交
96
            self.python_api = paddle.tensor.equal_all
97 98 99 100 101
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
H
hong 已提交
102
            self.check_output(check_eager=True)
103 104 105 106 107 108

    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'equal_all')
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


109 110
np_equal = lambda _x, _y: np.array(np.array_equal(_x, _y))

111
for _type_name in {'float32', 'float64', 'int32', 'int64', 'bool'}:
W
wawltor 已提交
112 113 114
    create_test_not_equal_class('equal_all', _type_name, np_equal)
    create_test_equal_class('equal_all', _type_name, np_equal)
    create_test_dim1_class('equal_all', _type_name, np_equal)
115 116 117


class TestEqualReduceAPI(unittest.TestCase):
118

119 120 121
    def test_name(self):
        x = fluid.layers.assign(np.array([3, 4], dtype="int32"))
        y = fluid.layers.assign(np.array([3, 4], dtype="int32"))
W
wawltor 已提交
122
        out = paddle.equal_all(x, y, name='equal_res')
123 124
        assert 'equal_res' in out.name

125 126 127 128 129 130 131 132
    def test_dynamic_api(self):
        paddle.disable_static()
        x = paddle.ones(shape=[10, 10], dtype="int32")
        y = paddle.ones(shape=[10, 10], dtype="int32")
        out = paddle.equal_all(x, y)
        assert out.numpy()[0] == True
        paddle.enable_static()

133 134 135

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