You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Paddle/python/paddle/fluid/tests/unittests/test_parameter.py

103 lines
3.8 KiB

# 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.
from __future__ import print_function
import unittest
import copy
import paddle
from paddle.fluid.dygraph import guard
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
import numpy as np
main_program = default_main_program()
class ParameterChecks(unittest.TestCase):
def check_parameter(self):
shape = [784, 100]
val = 1.0625
b = main_program.global_block()
param = b.create_parameter(
name='fc.w',
shape=shape,
dtype='float32',
initializer=ConstantInitializer(val))
self.assertIsNotNone(param)
self.assertEqual('fc.w', param.name)
self.assertEqual((784, 100), param.shape)
self.assertEqual(core.VarDesc.VarType.FP32, param.dtype)
self.assertEqual(0, param.block.idx)
exe = Executor(core.CPUPlace())
p = exe.run(main_program, fetch_list=[param])[0]
self.assertTrue(np.allclose(p, np.ones(shape) * val))
p = io.get_parameter_value_by_name('fc.w', exe, main_program)
self.assertTrue(np.allclose(np.array(p), np.ones(shape) * val))
def check_parambase(self):
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))
def check_exceptions(self):
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)
class TestParameter(ParameterChecks):
def _test_parameter(self):
self.check_parameter()
def test_parambase(self):
self.check_parambase()
def test_exceptions(self):
self.check_exceptions()
if __name__ == '__main__':
unittest.main()