test_base_layer.py 2.7 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


21
class L1(fluid.Layer):
22 23
    def __init__(self):
        super(L1, self).__init__()
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


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

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


45
class L3(fluid.Layer):
46 47 48 49
    def __init__(self):
        super(L3, self).__init__()
        self.layer1 = L2()
        self.layer2 = L2()
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():
58
            l = L1()
X
polish  
Xin Pan 已提交
59
            ret = l()
60 61 62 63 64
            expected_names = ['l1.w1', 'l1.w2']
            idx = 0
            for name, _ in l.named_parameters(prefix='l1'):
                self.assertEqual(name, expected_names[idx])
                idx += 1
65
            self.assertTrue(np.allclose(ret.numpy(), 0.2 * np.ones([2, 2])))
X
polish  
Xin Pan 已提交
66 67

    def test_three_level(self):
L
lujun 已提交
68
        with fluid.dygraph.guard():
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
            l = L3()
            expected_names = [
                'l3.layer1.layer1.w1',
                'l3.layer1.layer1.w2',
                'l3.layer1.layer2.w1',
                'l3.layer1.layer2.w2',
                'l3.layer2.layer1.w1',
                'l3.layer2.layer1.w2',
                'l3.layer2.layer2.w1',
                'l3.layer2.layer2.w2',
            ]
            idx = 0
            for name, _ in l.named_parameters(prefix='l3'):
                self.assertEqual(name, expected_names[idx])
                idx += 1
X
polish  
Xin Pan 已提交
84
            ret = l()
85
            self.assertTrue(np.allclose(ret.numpy(), 0.8 * np.ones([2, 2])))
X
polish  
Xin Pan 已提交
86 87 88 89


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