“83a577e8ce4114640a9fb2189befc577091581ee”上不存在“paddle/pten/kernels/expand_grad_kernel.h”
test_flatten_op.py 2.7 KB
Newer Older
1
#   Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
B
Bai Yifan 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
#
# 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 unittest

17
import numpy as np
B
Bai Yifan 已提交
18 19
from op_test import OpTest

张春乔 已提交
20 21
import paddle

B
Bai Yifan 已提交
22 23 24

class TestFlattenOp(OpTest):
    def setUp(self):
25
        self.op_type = "flatten"
B
Bai Yifan 已提交
26
        self.init_test_case()
27
        self.inputs = {"X": np.random.random(self.in_shape).astype("float64")}
B
Bai Yifan 已提交
28
        self.init_attrs()
29
        self.outputs = {"Out": self.inputs["X"].reshape(self.new_shape)}
B
Bai Yifan 已提交
30 31

    def test_check_output(self):
32
        self.check_output()
B
Bai Yifan 已提交
33 34 35 36 37

    def test_check_grad(self):
        self.check_grad(["X"], "Out")

    def init_test_case(self):
38
        self.in_shape = (3, 2, 2, 10)
B
Bai Yifan 已提交
39
        self.axis = 1
40
        self.new_shape = (3, 40)
B
Bai Yifan 已提交
41 42 43 44 45

    def init_attrs(self):
        self.attrs = {"axis": self.axis}


Z
zhangchunle 已提交
46
class TestFlattenOp1(TestFlattenOp):
B
Bai Yifan 已提交
47
    def init_test_case(self):
48
        self.in_shape = (3, 2, 2, 10)
B
Bai Yifan 已提交
49
        self.axis = 0
50
        self.new_shape = (1, 120)
B
Bai Yifan 已提交
51 52 53 54


class TestFlattenOpWithDefaultAxis(TestFlattenOp):
    def init_test_case(self):
Z
zhupengyang 已提交
55 56
        self.in_shape = (10, 2, 2, 3)
        self.new_shape = (10, 12)
B
Bai Yifan 已提交
57 58 59 60 61 62 63 64 65 66 67 68

    def init_attrs(self):
        self.attrs = {}


class TestFlattenOpSixDims(TestFlattenOp):
    def init_test_case(self):
        self.in_shape = (3, 2, 3, 2, 4, 4)
        self.axis = 4
        self.new_shape = (36, 16)


张春乔 已提交
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
class TestFlattenOpFP16(unittest.TestCase):
    def test_fp16_with_gpu(self):
        if paddle.fluid.core.is_compiled_with_cuda():
            place = paddle.CUDAPlace(0)
            with paddle.static.program_guard(
                paddle.static.Program(), paddle.static.Program()
            ):
                input = np.random.random([12, 14]).astype("float16")
                x = paddle.static.data(
                    name="x", shape=[12, 14], dtype="float16"
                )

                y = paddle.flatten(x)

                exe = paddle.static.Executor(place)
                res = exe.run(
                    paddle.static.default_main_program(),
                    feed={
                        "x": input,
                    },
                    fetch_list=[y],
                )

                assert np.array_equal(res[0].shape, [12 * 14])


B
Bai Yifan 已提交
95 96
if __name__ == "__main__":
    unittest.main()