test_gaussian_random_op.py 2.0 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.

15
import unittest
D
dzhwinter 已提交
16 17 18
import numpy

import paddle.v2.fluid as fluid
Q
Qiao Longfei 已提交
19 20
import paddle.v2.fluid.core as core
from paddle.v2.fluid.op import Operator
D
dzhwinter 已提交
21
from paddle.v2.fluid.executor import Executor
22 23


24
class TestGaussianRandomOp(unittest.TestCase):
D
dzhwinter 已提交
25 26 27 28 29 30 31
    def setUp(self):
        self.op_type = "gaussian_random"
        self.inputs = {}
        self.attrs = {"shape": [1000, 784], "mean": .0, "std": 1., "seed": 10}

        self.outputs = ["Out"]

32
    def test_cpu(self):
D
dzhwinter 已提交
33
        self.gaussian_random_test(place=fluid.CPUPlace())
34 35

    def test_gpu(self):
36
        if core.is_compiled_with_cuda():
D
dzhwinter 已提交
37
            self.gaussian_random_test(place=fluid.CUDAPlace(0))
38

39
    def gaussian_random_test(self, place):
D
dongzhihong 已提交
40

D
dzhwinter 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
        program = fluid.Program()
        block = program.global_block()
        vout = block.create_var(name="Out")
        op = block.append_op(
            type=self.op_type, outputs={"Out": vout}, attrs=self.attrs)

        op.desc.infer_var_type(block.desc)
        op.desc.infer_shape(block.desc)

        fetch_list = []
        for var_name in self.outputs:
            fetch_list.append(block.var(var_name))

        exe = Executor(place)
        outs = exe.run(program, fetch_list=fetch_list)
        tensor = outs[0]

58 59
        self.assertAlmostEqual(numpy.mean(tensor), .0, delta=0.1)
        self.assertAlmostEqual(numpy.std(tensor), 1., delta=0.1)
60 61


Q
qijun 已提交
62
if __name__ == "__main__":
63
    unittest.main()