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.

Y
Yu Yang 已提交
15
import unittest
16 17 18 19 20
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 已提交
21
import numpy as np
Y
Yu Yang 已提交
22

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

Y
Yu Yang 已提交
25 26 27

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


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