test_transpose_mkldnn_op.py 2.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
# Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
#
# 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
18

19
from paddle.fluid.tests.unittests.eager_op_test import OpTest
20

21

22
class TestTransposeMKLDNN(OpTest):
23 24 25 26 27 28 29 30 31 32
    def setUp(self):
        self.init_op_type()
        self.initTestCase()
        self.inputs = {'X': np.random.random(self.shape).astype("float32")}
        self.attrs = {
            'axis': list(self.axis),
            'use_mkldnn': self.use_mkldnn,
        }
        self.outputs = {
            'XShape': np.random.random(self.shape).astype("float32"),
33
            'Out': self.inputs['X'].transpose(self.axis),
34 35
        }

36 37 38 39 40
    def init_op_type(self):
        self.op_type = "transpose2"
        self.use_mkldnn = True
        return

41 42 43 44 45 46 47 48 49
    def test_check_output(self):
        # TODO(wangzhongpu): support mkldnn op in dygraph mode
        self.check_output(no_check_set=['XShape'], check_dygraph=False)

    def test_check_grad(self):
        # TODO(wangzhongpu): support mkldnn op in dygraph mode
        self.check_grad(['X'], 'Out', check_dygraph=False)

    def initTestCase(self):
50
        self.shape = (30, 4)
51 52
        self.axis = (1, 0)

53 54 55

class TestCase0MKLDNN(TestTransposeMKLDNN):
    def initTestCase(self):
56 57
        self.shape = (100,)
        self.axis = (0,)
58 59 60 61


class TestCase1a(TestTransposeMKLDNN):
    def initTestCase(self):
Z
zhupengyang 已提交
62
        self.shape = (3, 4, 10)
63 64 65 66 67
        self.axis = (0, 2, 1)


class TestCase1b(TestTransposeMKLDNN):
    def initTestCase(self):
Z
zhupengyang 已提交
68
        self.shape = (3, 4, 10)
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
        self.axis = (2, 1, 0)


class TestCase2(TestTransposeMKLDNN):
    def initTestCase(self):
        self.shape = (2, 3, 4, 5)
        self.axis = (0, 2, 3, 1)


class TestCase3(TestTransposeMKLDNN):
    def initTestCase(self):
        self.shape = (2, 3, 4, 5, 6)
        self.axis = (4, 2, 3, 1, 0)


class TestCase4(TestTransposeMKLDNN):
    def initTestCase(self):
        self.shape = (2, 3, 4, 5, 6, 1)
        self.axis = (4, 2, 3, 1, 0, 5)


90 91 92 93 94 95
class TestCase_ZeroDim(TestTransposeMKLDNN):
    def initTestCase(self):
        self.shape = ()
        self.axis = ()


96 97
if __name__ == '__main__':
    unittest.main()