test_parameter.py 1.8 KB
Newer Older
D
dzhwinter 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
#  Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserve.
#
#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.
Y
Yu Yang 已提交
14
import unittest
Y
Yu Yang 已提交
15
from paddle.v2.fluid.framework import default_main_program
Q
Qiao Longfei 已提交
16
import paddle.v2.fluid.core as core
X
xuwei06 已提交
17 18 19 20
from paddle.v2.fluid.executor import Executor
import paddle.v2.fluid.io as io
from paddle.v2.fluid.initializer import ConstantInitializer
import numpy as np
Y
Yu Yang 已提交
21

Y
Yu Yang 已提交
22 23
main_program = default_main_program()

Y
Yu Yang 已提交
24 25 26

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


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