# 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()