test_parameter.py 1.8 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 21 22
from paddle.fluid.framework import default_main_program
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 已提交
23
import numpy as np
Y
Yu Yang 已提交
24

Y
Yu Yang 已提交
25 26
main_program = default_main_program()

Y
Yu Yang 已提交
27 28 29

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


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