test_base_layer.py 2.6 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 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
# 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 contextlib
import unittest
import numpy as np
import six
import sys

import paddle
import paddle.fluid as fluid
from paddle.fluid.layer_helper import LayerHelper


class L1(fluid.imperative.Layer):
    def __init__(self):
        super(L1, self).__init__()
        self._helper = LayerHelper(
            'MyLayer',
            param_attr=fluid.ParamAttr(
                initializer=fluid.initializer.Constant(value=0.1)))

        self.w1 = self._helper.create_parameter(
            attr=self._helper.param_attr,
            shape=[2, 2],
            dtype='float32',
            is_bias=False)
        self.w2 = self._helper.create_parameter(
            attr=self._helper.param_attr,
            shape=[2, 2],
            dtype='float32',
            is_bias=False)

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


class L2(fluid.imperative.Layer):
    def __init__(self):
        super(L2, self).__init__()
        self.layer1 = L1()
        self.layer2 = L1()

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


class L3(fluid.imperative.Layer):
    def __init__(self):
        super(L3, self).__init__()
        self.layer1 = L2()
        self.layer2 = L2()

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


class TestBaseLayer(unittest.TestCase):
    def test_one_level(self):
        with fluid.imperative.guard():
            l = L1()
            ret = l()
            self.assertEqual(l.w1.name, "MyLayer_0.w_0")
            self.assertEqual(l.w2.name, "MyLayer_0.w_1")
            self.assertTrue(np.allclose(ret._numpy(), 0.2 * np.ones([2, 2])))
            sys.stderr.write(
                '%s %s %s %s\n' %
                (ret._numpy(), l.w1.name, l.w2.name, l._sub_layers))

    def test_three_level(self):
        with fluid.imperative.guard():
            l = L3()
            ret = l()
            sys.stderr.write('%s\n' % ret._numpy())

            for p in l.parameters():
                sys.stderr.write('%s\n' % p.name)


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