test_tensor_zero_.py 1.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
# Copyright (c) 2019 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.

import paddle.fluid as fluid
import unittest
import numpy as np
import six
import paddle
20
from paddle.fluid.framework import _test_eager_guard
21 22 23 24 25 26


class TensorFill_Test(unittest.TestCase):
    def setUp(self):
        self.shape = [32, 32]

27
    def func_test_tensor_fill_true(self):
28 29 30 31 32 33 34 35 36 37 38
        typelist = ['float32', 'float64', 'int32', 'int64', 'float16']
        places = [fluid.CPUPlace()]
        if fluid.core.is_compiled_with_cuda():
            places.append(fluid.CUDAPlace(0))
            places.append(fluid.CUDAPinnedPlace())

        for p in places:
            np_arr = np.reshape(
                np.array(six.moves.range(np.prod(self.shape))), self.shape)
            for dtype in typelist:
                tensor = paddle.to_tensor(np_arr, place=p, dtype=dtype)
39 40
                target = tensor.numpy()
                target[...] = 0
41 42

                tensor.zero_()
43
                self.assertEqual((tensor.numpy() == target).all().item(), True)
44

45 46 47 48 49
    def test_tensor_fill_true(self):
        with _test_eager_guard():
            self.func_test_tensor_fill_true()
        self.func_test_tensor_fill_true()

50 51 52

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