test_compare_reduce_op.py 4.5 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):
        def setUp(self):
W
wawltor 已提交
28 29
            x = np.random.random(size=(10, 7)).astype(typename)
            y = np.random.random(size=(10, 7)).astype(typename)
30 31 32 33 34 35 36 37
            z = callback(x, y)
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
            self.check_output()

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


W
wawltor 已提交
43
def create_test_not_shape_equal_class(op_type, typename, callback):
44 45 46
    class Cls(op_test.OpTest):
        def setUp(self):
            x = np.random.random(size=(10, 7)).astype(typename)
W
wawltor 已提交
47
            y = np.random.random(size=(10)).astype(typename)
48 49 50 51 52 53 54 55
            z = callback(x, y)
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
            self.check_output()

W
wawltor 已提交
56
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'not_shape_equal_all')
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


def create_test_equal_class(op_type, typename, callback):
    class Cls(op_test.OpTest):
        def setUp(self):
            x = y = np.random.random(size=(10, 7)).astype(typename)
            z = callback(x, y)
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
            self.check_output()

W
wawltor 已提交
73
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'equal_all')
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


def create_test_dim1_class(op_type, typename, callback):
    class Cls(op_test.OpTest):
        def setUp(self):
            x = y = np.random.random(size=(1)).astype(typename)
            z = callback(x, y)
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
            self.check_output()

W
wawltor 已提交
90
    cls_name = "{0}_{1}_{2}".format(op_type, typename, 'equal_all')
91 92 93 94
    Cls.__name__ = cls_name
    globals()[cls_name] = Cls


95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
def create_test_dim1_class(op_type, typename, callback):
    class Cls(op_test.OpTest):
        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)
            self.inputs = {'X': x, 'Y': y}
            self.outputs = {'Out': z}
            self.op_type = op_type

        def test_output(self):
            self.check_output()

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


114 115
np_equal = lambda _x, _y: np.array(np.array_equal(_x, _y))

116
for _type_name in {'float32', 'float64', 'int32', 'int64', 'bool'}:
W
wawltor 已提交
117 118 119
    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)
120 121 122 123 124 125


class TestEqualReduceAPI(unittest.TestCase):
    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 已提交
126
        out = paddle.equal_all(x, y, name='equal_res')
127 128
        assert 'equal_res' in out.name

129 130 131 132 133 134 135 136
    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()

137 138 139

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