test_parameter.py 5.0 KB
Newer Older
1
#   Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
D
dzhwinter 已提交
2
#
D
dzhwinter 已提交
3 4 5
# 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
D
dzhwinter 已提交
6
#
D
dzhwinter 已提交
7
#     http://www.apache.org/licenses/LICENSE-2.0
D
dzhwinter 已提交
8
#
D
dzhwinter 已提交
9 10 11 12 13 14
# 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.

15 16
from __future__ import print_function

Y
Yu Yang 已提交
17
import unittest
18 19 20
import copy
import paddle
from paddle.fluid.dygraph import guard
J
Jiabin Yang 已提交
21
from paddle.fluid.framework import default_main_program, Variable, _test_eager_guard
22 23 24 25
import paddle.fluid.core as core
from paddle.fluid.executor import Executor
import paddle.fluid.io as io
from paddle.fluid.initializer import ConstantInitializer
X
xuwei06 已提交
26
import numpy as np
Y
Yu Yang 已提交
27

28
paddle.enable_static()
Y
Yu Yang 已提交
29 30
main_program = default_main_program()

Y
Yu Yang 已提交
31

32
class ParameterChecks(unittest.TestCase):
33
    def test_parameter(self):
X
xuwei06 已提交
34 35
        shape = [784, 100]
        val = 1.0625
Y
Yu Yang 已提交
36
        b = main_program.global_block()
Y
Yu Yang 已提交
37 38
        param = b.create_parameter(
            name='fc.w',
X
xuwei06 已提交
39
            shape=shape,
Y
Yu Yang 已提交
40
            dtype='float32',
X
xuwei06 已提交
41
            initializer=ConstantInitializer(val))
Y
Yu Yang 已提交
42 43 44
        self.assertIsNotNone(param)
        self.assertEqual('fc.w', param.name)
        self.assertEqual((784, 100), param.shape)
45
        self.assertEqual(core.VarDesc.VarType.FP32, param.dtype)
Y
Yu Yang 已提交
46
        self.assertEqual(0, param.block.idx)
47
        exe = Executor(paddle.CPUPlace())
Y
Yu Yang 已提交
48
        p = exe.run(main_program, fetch_list=[param])[0]
49
        self.assertTrue(np.array_equal(p, np.ones(shape) * val))
Y
Yu Yang 已提交
50
        p = io.get_parameter_value_by_name('fc.w', exe, main_program)
51
        self.assertTrue(np.array_equal(p, np.ones(shape) * val))
Y
Yu Yang 已提交
52

J
Jiabin Yang 已提交
53
    def func_parambase(self):
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
        with guard():
            linear = paddle.nn.Linear(10, 10)
            param = linear.weight

            memo = {}
            param_copy = copy.deepcopy(param, memo)
            self.assertEqual(param_copy.shape, param.shape)
            self.assertEqual(param_copy.type, param.type)
            self.assertEqual(param_copy.dtype, param.dtype)
            self.assertEqual(str(param_copy.place), str(param.place))
            self.assertTrue(np.array_equal(param_copy.numpy(), param.numpy()))
            self.assertEqual(param_copy.optimize_attr, param.optimize_attr)
            self.assertEqual(param_copy.regularizer, param.regularizer)
            self.assertEqual(param_copy.do_model_average,
                             param.do_model_average)
            self.assertEqual(param_copy.need_clip, param.need_clip)
            self.assertEqual(param_copy.is_distributed, param.is_distributed)

            pram_copy2 = copy.deepcopy(param, memo)
            self.assertEqual(id(param_copy), id(pram_copy2))

J
Jiabin Yang 已提交
75 76 77 78 79 80
    def test_parambase(self):
        with _test_eager_guard():
            self.func_parambase()
        self.func_parambase()

    def func_exception(self):
81 82 83 84 85 86 87 88 89 90 91 92 93 94
        b = main_program.global_block()
        with self.assertRaises(ValueError):
            b.create_parameter(
                name='test', shape=None, dtype='float32', initializer=None)
        with self.assertRaises(ValueError):
            b.create_parameter(
                name='test', shape=[1], dtype=None, initializer=None)
        with self.assertRaises(ValueError):
            b.create_parameter(
                name='test', shape=[], dtype='float32', initializer=None)
        with self.assertRaises(ValueError):
            b.create_parameter(
                name='test', shape=[-1], dtype='float32', initializer=None)

J
Jiabin Yang 已提交
95
    def func_parambase_to_vector(self):
96 97 98 99
        with guard():
            initializer = paddle.ParamAttr(
                initializer=paddle.nn.initializer.Constant(3.))
            linear1 = paddle.nn.Linear(10, 15, initializer)
Y
Yu Yang 已提交
100

101 102 103 104 105
            vec = paddle.nn.utils.parameters_to_vector(linear1.parameters())
            self.assertEqual(linear1.weight.shape, [10, 15])
            self.assertEqual(linear1.bias.shape, [15])
            self.assertTrue(isinstance(vec, Variable))
            self.assertTrue(vec.shape, [165])
106

107 108 109 110 111 112 113 114 115 116 117 118
            linear2 = paddle.nn.Linear(10, 15)
            paddle.nn.utils.vector_to_parameters(vec, linear2.parameters())
            self.assertEqual(linear2.weight.shape, [10, 15])
            self.assertEqual(linear2.bias.shape, [15])
            self.assertTrue(
                np.array_equal(linear1.weight.numpy(), linear2.weight.numpy()),
                True)
            self.assertTrue(
                np.array_equal(linear1.bias.numpy(), linear2.bias.numpy()),
                True)
            self.assertTrue(linear2.weight.is_leaf, True)
            self.assertTrue(linear2.bias.is_leaf, True)
119

J
Jiabin Yang 已提交
120 121 122 123 124
    def test_parambase_to_vector(self):
        with _test_eager_guard():
            self.func_parambase_to_vector()
        self.func_parambase_to_vector()

125

Y
Yu Yang 已提交
126 127
if __name__ == '__main__':
    unittest.main()