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

L
LiYuRio 已提交
17
import paddle
18 19
import paddle.fluid.core as core
import paddle.fluid.framework as framework
20
import paddle.fluid.layers as layers
21 22
from paddle.fluid.executor import Executor
from paddle.fluid.framework import default_startup_program
23 24 25 26 27 28 29 30 31 32


class TestSwitch(unittest.TestCase):
    def check_switch(self, value):
        x = layers.fill_constant(shape=[1], dtype='float32', value=value)
        zero_var = layers.fill_constant(shape=[1], dtype='float32', value=0.0)
        one_var = layers.fill_constant(shape=[1], dtype='float32', value=1.0)
        two_var = layers.fill_constant(shape=[1], dtype='float32', value=2.0)
        three_var = layers.fill_constant(shape=[1], dtype='float32', value=3.0)

33 34 35
        result = layers.create_global_var(
            shape=[1], value=-1.0, dtype='float32', persistable=True
        )
36 37

        with layers.Switch() as switch:
L
LiYuRio 已提交
38
            with switch.case(paddle.less_than(x, zero_var)):
39
                layers.assign(zero_var, result)
L
LiYuRio 已提交
40
            with switch.case(paddle.less_than(x, one_var)):
41
                layers.assign(one_var, result)
L
LiYuRio 已提交
42
            with switch.case(paddle.less_than(x, two_var)):
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
                layers.assign(two_var, result)
            with switch.default():
                layers.assign(three_var, result)

        cpu = core.CPUPlace()
        exe = Executor(cpu)
        exe.run(default_startup_program())

        out = exe.run(feed={}, fetch_list=[result])[0][0]
        return out

    def test_switch(self):
        test_data = {(-0.1, 0), (0.1, 1), (1.1, 2), (2.1, 3)}
        for x, expected_result in test_data:
            main_program = framework.Program()
            startup_program = framework.Program()
            with framework.program_guard(main_program, startup_program):
                result = self.check_switch(x)
                self.assertEqual(result, expected_result)


64 65 66 67 68 69
class TestSwitchCaseError(unittest.TestCase):
    def test_error(self):
        main_program = framework.Program()
        startup_program = framework.Program()
        with framework.program_guard(main_program, startup_program):
            cond = layers.fill_constant(shape=[1], dtype='float32', value=0.0)
70 71 72 73 74 75 76
            zero_var = layers.fill_constant(
                shape=[1], dtype='float32', value=0.0
            )

            result = layers.create_global_var(
                shape=[1], value=-1.0, dtype='float32', persistable=True
            )
77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94

            # 1. The type of 'condition' in case must be Variable.
            def test_condition_type():
                with layers.Switch() as switch:
                    with switch.case(1):
                        layers.assign(zero_var, result)

            self.assertRaises(TypeError, test_condition_type)

            # 2. The dtype of 'condition' in case must be 'bool'.
            def test_condition_dtype():
                with layers.Switch() as switch:
                    with switch.case(cond):
                        layers.assign(zero_var, result)

            self.assertRaises(TypeError, test_condition_dtype)


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