test_reshape_op.py 3.1 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.

Y
Yibing Liu 已提交
15 16
import unittest
import numpy as np
Y
ying 已提交
17
import pdb
Y
Yibing Liu 已提交
18

Y
ying 已提交
19
from op_test import OpTest
Y
Yibing Liu 已提交
20

Y
ying 已提交
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
# class TestReshapeOp1(OpTest):
#     def setUp(self):
#         ori_shape = (2, 25)
#         new_shape = [5, 10]
# 
#         self.op_type = "reshape"
#         self.inputs = {"X": np.random.random(ori_shape).astype("float32")}
#         self.attrs = {"shape": new_shape}
#         self.outputs = {"Out": self.inputs["X"].reshape(new_shape)}
# 
#     def test_check_output(self):
#         self.check_output()
# 
#     def test_check_grad(self):
#         self.check_grad(["X"], "Out")
C
caoying03 已提交
36 37
# 
# 
Y
ying 已提交
38 39 40 41 42 43 44 45 46 47 48 49
# class TestReshapeOpDimInfer1(OpTest):
#     def setUp(self):
#         self.op_type = "reshape"
#         self.inputs = {"X": np.random.random((5, 10)).astype("float32")}
#         self.attrs = {"shape": [5, -1, 5]}
#         self.outputs = {"Out": self.inputs["X"].reshape(self.attrs["shape"])}
# 
#     def test_check_output(self):
#         self.check_output()
# 
#     def test_check_grad(self):
#         self.check_grad(["X"], "Out")
Y
Yibing Liu 已提交
50 51


Y
ying 已提交
52
class TestReshapeOp2(OpTest):
53
    def setUp(self):
Y
ying 已提交
54 55 56
        ori_shape = (2, 25)
        new_shape = ([5, 10], )

57
        self.op_type = "reshape"
Y
ying 已提交
58 59
        self.inputs = {
            "X": np.random.random(ori_shape).astype("float32"),
C
caoying03 已提交
60 61
            "Shape": np.array(
                new_shape, dtype="int64")
Y
ying 已提交
62 63
        }
        self.outputs = {"Out": self.inputs["X"].reshape(new_shape[0])}
64 65 66 67 68 69 70 71

    def test_check_output(self):
        self.check_output()

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


C
caoying03 已提交
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
# class TestReshapeOpInplace(OpTest):
#     def setUp(self):
#         self.op_type = "reshape"
#         self.inputs = {'X': np.random.random((10, 20)).astype("float32")}
#         self.attrs = {'shape': [10 * 20], 'inplace': True}
#         self.outputs = {'Out': self.inputs['X'].reshape(self.attrs['shape'])}
# 
#     def test_check_output(self):
#         self.check_output()
# 
#     def test_check_grad(self):
#         self.check_grad(["X"], "Out")
# 
# 
# class TestReshapeOpDimInferInplace(OpTest):
#     def setUp(self):
#         self.op_type = "reshape"
#         self.inputs = {'X': np.random.random((10, 20)).astype("float32")}
#         self.attrs = {'shape': [4, -1, 5], 'inplace': True}
#         self.outputs = {'Out': self.inputs['X'].reshape(self.attrs['shape'])}
# 
#     def test_check_output(self):
#         self.check_output()
# 
#     def test_check_grad(self):
#         self.check_grad(["X"], "Out")

Y
ying 已提交
99
if __name__ == "__main__":
Y
Yibing Liu 已提交
100
    unittest.main()