test_label_smooth_functional.py 4.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
# 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 numpy as np
import paddle
17
from paddle import fluid
18 19 20 21 22 23
import paddle.fluid.dygraph as dg
import paddle.nn.functional as F
import unittest


class LabelSmoothTestCase(unittest.TestCase):
24 25 26 27 28 29 30 31
    def __init__(
        self,
        methodName='runTest',
        label_shape=(20, 1),
        prior_dist=None,
        epsilon=0.1,
        dtype="float32",
    ):
32
        super().__init__(methodName)
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47

        self.label_shape = label_shape
        self.prior_dist = prior_dist
        self.dtype = dtype
        self.epsilon = epsilon

    def setUp(self):
        self.label = np.random.randn(*(self.label_shape)).astype(self.dtype)

    def fluid_layer(self, place):
        paddle.enable_static()
        main = fluid.Program()
        start = fluid.Program()
        with fluid.unique_name.guard():
            with fluid.program_guard(main, start):
48 49 50
                label_var = fluid.data(
                    "input", self.label_shape, dtype=self.dtype
                )
51
                y_var = F.label_smooth(
52 53 54 55
                    label_var,
                    prior_dist=self.prior_dist,
                    epsilon=self.epsilon,
                )
56 57 58
        feed_dict = {"input": self.label}
        exe = fluid.Executor(place)
        exe.run(start)
59
        (y_np,) = exe.run(main, feed=feed_dict, fetch_list=[y_var])
60 61 62 63 64 65 66 67
        return y_np

    def functional(self, place):
        paddle.enable_static()
        main = fluid.Program()
        start = fluid.Program()
        with fluid.unique_name.guard():
            with fluid.program_guard(main, start):
68 69 70 71 72 73
                label_var = fluid.data(
                    "input", self.label_shape, dtype=self.dtype
                )
                y_var = F.label_smooth(
                    label_var, prior_dist=self.prior_dist, epsilon=self.epsilon
                )
74 75 76
        feed_dict = {"input": self.label}
        exe = fluid.Executor(place)
        exe.run(start)
77
        (y_np,) = exe.run(main, feed=feed_dict, fetch_list=[y_var])
78 79 80 81 82
        return y_np

    def paddle_dygraph_layer(self):
        paddle.disable_static()
        label_var = dg.to_variable(self.label)
83 84 85
        y_var = F.label_smooth(
            label_var, prior_dist=self.prior_dist, epsilon=self.epsilon
        )
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
        y_np = y_var.numpy()
        return y_np

    def _test_equivalence(self, place):
        place = fluid.CPUPlace()
        result1 = self.fluid_layer(place)
        result2 = self.functional(place)
        result3 = self.paddle_dygraph_layer()
        np.testing.assert_array_almost_equal(result1, result2)
        np.testing.assert_array_almost_equal(result2, result3)

    def runTest(self):
        place = fluid.CPUPlace()
        self._test_equivalence(place)
        if fluid.core.is_compiled_with_cuda():
            place = fluid.CUDAPlace(0)
            self._test_equivalence(place)


class LabelSmoothErrorTestCase(LabelSmoothTestCase):
    def runTest(self):
        place = fluid.CPUPlace()
        with dg.guard(place):
            with self.assertRaises(ValueError):
                self.paddle_dygraph_layer()


def add_cases(suite):
    suite.addTest(LabelSmoothTestCase(methodName='runTest'))
    suite.addTest(
116 117
        LabelSmoothTestCase(methodName='runTest', label_shape=[2, 3, 1])
    )
118 119 120 121 122 123 124 125 126 127 128 129 130 131 132


def add_error_cases(suite):
    suite.addTest(LabelSmoothErrorTestCase(methodName='runTest', epsilon=2))


def load_tests(loader, standard_tests, pattern):
    suite = unittest.TestSuite()
    add_cases(suite)
    add_error_cases(suite)
    return suite


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