aboutsummaryrefslogtreecommitdiffhomepage
path: root/tensorflow/compiler/tests
diff options
context:
space:
mode:
authorGravatar Adrian Kuegel <akuegel@google.com>2018-10-04 05:34:55 -0700
committerGravatar TensorFlower Gardener <gardener@tensorflow.org>2018-10-04 05:38:38 -0700
commit28f239fdfa0c94f715fccf0197ab6c3c8df27d28 (patch)
tree9a5998dc21a3428c292e597afce0a4a15ffeee26 /tensorflow/compiler/tests
parent9cd6cab4f85f1f35c6532da3fb68839294d44ee4 (diff)
Implement DataFormatVecPermute for XLA.
Also clear "_kernel" attributes of nodes if they are set to "host". This is not meaningful when processing the graph for XLA, and it would prevent finding the registered XLA kernel. PiperOrigin-RevId: 215722216
Diffstat (limited to 'tensorflow/compiler/tests')
-rw-r--r--tensorflow/compiler/tests/BUILD13
-rw-r--r--tensorflow/compiler/tests/permute_test.py80
2 files changed, 93 insertions, 0 deletions
diff --git a/tensorflow/compiler/tests/BUILD b/tensorflow/compiler/tests/BUILD
index 822fedf121..ee36729fd1 100644
--- a/tensorflow/compiler/tests/BUILD
+++ b/tensorflow/compiler/tests/BUILD
@@ -1029,6 +1029,19 @@ tf_xla_py_test(
)
tf_xla_py_test(
+ name = "permute_test",
+ size = "small",
+ srcs = ["permute_test.py"],
+ deps = [
+ "//tensorflow/compiler/tests:xla_test",
+ "//tensorflow/python:array_ops",
+ "//tensorflow/python:client_testlib",
+ "//tensorflow/python:dtypes",
+ "//tensorflow/python:nn_ops",
+ ],
+)
+
+tf_xla_py_test(
name = "xla_device_test",
size = "small",
srcs = ["xla_device_test.py"],
diff --git a/tensorflow/compiler/tests/permute_test.py b/tensorflow/compiler/tests/permute_test.py
new file mode 100644
index 0000000000..dbb9274df4
--- /dev/null
+++ b/tensorflow/compiler/tests/permute_test.py
@@ -0,0 +1,80 @@
+# Copyright 2018 The TensorFlow 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.
+# ==============================================================================
+"""Tests for the DataFormatVecPermute operator."""
+
+from __future__ import absolute_import
+from __future__ import division
+from __future__ import print_function
+
+import numpy as np
+
+from tensorflow.compiler.tests import xla_test
+from tensorflow.python.framework import dtypes
+from tensorflow.python.ops import array_ops
+from tensorflow.python.ops import nn_ops
+from tensorflow.python.platform import test
+
+
+class XlaPermuteOpTest(xla_test.XLATestCase):
+
+ def _runPermuteAndCompare(self, x, src_format, dst_format, expected):
+ with self.cached_session() as session:
+ with self.test_scope():
+ placeholder = array_ops.placeholder(dtypes.as_dtype(x.dtype), x.shape)
+ param = {placeholder: x}
+ output = nn_ops.data_format_vec_permute(
+ placeholder, src_format=src_format, dst_format=dst_format)
+ result = session.run(output, param)
+ self.assertAllEqual(result, expected)
+
+ def testNHWCToNCHW(self):
+ x = np.array([7, 4, 9, 3], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NHWC", "NCHW", [7, 3, 4, 9])
+
+ def testNCHWToNHWC(self):
+ x = np.array([7, 4, 9, 3], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NCHW", "NHWC", [7, 9, 3, 4])
+
+ def testNHWCToHWNC(self):
+ x = np.array([7, 4, 9, 3], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NHWC", "HWNC", [4, 9, 7, 3])
+
+ def testHWNCToNHWC(self):
+ x = np.array([7, 4, 9, 3], dtype=np.int32)
+ self._runPermuteAndCompare(x, "HWNC", "NHWC", [9, 7, 4, 3])
+
+ def testNHWCToNCHW2D(self):
+ x = np.array([[7, 4], [9, 3], [4, 5], [5, 1]], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NHWC", "NCHW",
+ [[7, 4], [5, 1], [9, 3], [4, 5]])
+
+ def testNHWCToHWNC2D(self):
+ x = np.array([[7, 4], [9, 3], [4, 5], [5, 1]], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NHWC", "HWNC",
+ [[9, 3], [4, 5], [7, 4], [5, 1]])
+
+ def testHWNCToNHWC2D(self):
+ x = np.array([[7, 4], [9, 3], [4, 5], [5, 1]], dtype=np.int32)
+ self._runPermuteAndCompare(x, "HWNC", "NHWC",
+ [[4, 5], [7, 4], [9, 3], [5, 1]])
+
+ def testNCHWToNHWC2D(self):
+ x = np.array([[7, 4], [9, 3], [4, 5], [5, 1]], dtype=np.int32)
+ self._runPermuteAndCompare(x, "NCHW", "NHWC",
+ [[7, 4], [4, 5], [5, 1], [9, 3]])
+
+
+if __name__ == "__main__":
+ test.main()