test_gaussian_random_op.py 1.9 KB
Newer Older
D
dzhwinter 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
#  Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserve.
#
#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.
14
import unittest
D
dzhwinter 已提交
15 16 17
import numpy

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


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

        self.outputs = ["Out"]

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

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

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

D
dzhwinter 已提交
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
        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]

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


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