test_fc_op.py 1.1 KB
Newer Older
1 2 3
import paddle.v2.framework.core as core
import unittest
import numpy
4
from paddle.v2.framework.op import Operator
5 6 7 8


class TestFc(unittest.TestCase):
    def test_fc(self):
9
        scope = core.Scope()
Q
qijun 已提交
10
        place = core.CPUPlace()
11
        x = scope.new_var("X")
Q
qijun 已提交
12

13 14
        x_tensor = x.get_tensor()
        x_tensor.set_dims([1000, 784])
Q
qijun 已提交
15
        x_tensor.alloc_float(place)
16

17
        w = scope.new_var("W")
18 19
        w_tensor = w.get_tensor()
        w_tensor.set_dims([784, 100])
Q
qijun 已提交
20
        w_tensor.alloc_float(place)
21

Q
qijun 已提交
22
        w_tensor.set(numpy.random.random((784, 100)).astype("float32"), place)
23 24 25 26

        # Set a real numpy array here.
        # x_tensor.set(numpy.array([]))

27
        op = Operator("fc", X="X", Y="Y", W="W")
28 29

        for out in op.outputs():
30 31
            if scope.find_var(out) is None:
                scope.new_var(out).get_tensor()
32

33
        tensor = scope.find_var("Y").get_tensor()
34 35 36
        op.infer_shape(scope)
        self.assertEqual([1000, 100], tensor.shape())

Q
qijun 已提交
37
        ctx = core.DeviceContext.create(place)
38 39 40 41 42 43 44 45

        op.run(scope, ctx)

        # After complete all ops, check Y is expect or not.


if __name__ == '__main__':
    unittest.main()
新手
引导
客服 返回
顶部