test_base_layer.py 2.8 KB
Newer Older
X
polish  
Xin Pan 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
# 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.

import unittest
import numpy as np

import paddle.fluid as fluid


L
lujun 已提交
21
class L1(fluid.dygraph.Layer):
X
Xin Pan 已提交
22 23
    def __init__(self, prefix):
        super(L1, self).__init__(prefix)
24 25 26 27 28 29
        self._param_attr = fluid.ParamAttr(
            initializer=fluid.initializer.Constant(value=0.1))
        self.w1 = self.create_parameter(
            attr=self._param_attr, shape=[2, 2], dtype='float32', is_bias=False)
        self.w2 = self.create_parameter(
            attr=self._param_attr, shape=[2, 2], dtype='float32', is_bias=False)
X
polish  
Xin Pan 已提交
30 31 32 33 34

    def forward(self):
        return self.w1 + self.w2


L
lujun 已提交
35
class L2(fluid.dygraph.Layer):
X
Xin Pan 已提交
36 37 38 39
    def __init__(self, prefix):
        super(L2, self).__init__(prefix)
        self.layer1 = L1(self.full_name())
        self.layer2 = L1(self.full_name())
X
polish  
Xin Pan 已提交
40 41 42 43 44

    def forward(self):
        return self.layer1() + self.layer2()


L
lujun 已提交
45
class L3(fluid.dygraph.Layer):
X
Xin Pan 已提交
46 47 48 49
    def __init__(self, prefix):
        super(L3, self).__init__(prefix)
        self.layer1 = L2(self.full_name())
        self.layer2 = L2(self.full_name())
X
polish  
Xin Pan 已提交
50 51 52 53 54 55 56

    def forward(self):
        return self.layer1() + self.layer2()


class TestBaseLayer(unittest.TestCase):
    def test_one_level(self):
L
lujun 已提交
57
        with fluid.dygraph.guard():
X
Xin Pan 已提交
58
            l = L1('test_one_level')
X
polish  
Xin Pan 已提交
59
            ret = l()
60 61
            self.assertEqual(l.w1.name, "test_one_level/L1_0.w_0")
            self.assertEqual(l.w2.name, "test_one_level/L1_0.w_1")
X
polish  
Xin Pan 已提交
62 63 64
            self.assertTrue(np.allclose(ret._numpy(), 0.2 * np.ones([2, 2])))

    def test_three_level(self):
L
lujun 已提交
65
        with fluid.dygraph.guard():
X
Xin Pan 已提交
66 67
            l = L3('test_three_level')
            names = [p.name for p in l.parameters()]
X
polish  
Xin Pan 已提交
68
            ret = l()
69 70 71 72 73 74
            self.assertEqual(names[0], "test_three_level/L3_0/L2_0/L1_0.w_0")
            self.assertEqual(names[1], "test_three_level/L3_0/L2_0/L1_0.w_1")
            self.assertEqual(names[2], "test_three_level/L3_0/L2_0/L1_1.w_0")
            self.assertEqual(names[3], "test_three_level/L3_0/L2_0/L1_1.w_1")
            self.assertEqual(names[4], "test_three_level/L3_0/L2_1/L1_0.w_0")
            self.assertEqual(names[5], "test_three_level/L3_0/L2_1/L1_0.w_1")
X
Xin Pan 已提交
75
            self.assertTrue(np.allclose(ret._numpy(), 0.8 * np.ones([2, 2])))
X
polish  
Xin Pan 已提交
76 77 78 79


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