This is an automated email from the ASF dual-hosted git repository.
zhaowu pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/incubator-tvm.git
The following commit(s) were added to refs/heads/master by this push:
new 6914963 [Relay][Frontend][TFlite] Add add parser support for
relational ops (#4695)
6914963 is described below
commit 6914963545a10c3c031c154f89a51a587e154743
Author: Ina Dobreva <[email protected]>
AuthorDate: Thu Jan 30 14:10:52 2020 +0000
[Relay][Frontend][TFlite] Add add parser support for relational ops (#4695)
Add support for: greater_equal, less, less_equal, equal, not_equal
Add tests for the elemwise relational ops
---
python/tvm/relay/frontend/tflite.py | 57 +++++++++++++++++++++++++---
tests/python/frontend/tflite/test_forward.py | 39 +++++++++++++++++++
2 files changed, 90 insertions(+), 6 deletions(-)
diff --git a/python/tvm/relay/frontend/tflite.py
b/python/tvm/relay/frontend/tflite.py
index 5902b92..791c056 100644
--- a/python/tvm/relay/frontend/tflite.py
+++ b/python/tvm/relay/frontend/tflite.py
@@ -89,6 +89,11 @@ class OperatorConverter(object):
'MAXIMUM': self.convert_maximum,
'MINIMUM': self.convert_minimum,
'GREATER': self.convert_greater,
+ 'GREATER_EQUAL': self.convert_greater_equal,
+ 'LESS': self.convert_less,
+ 'LESS_EQUAL': self.convert_less_equal,
+ 'EQUAL': self.convert_equal,
+ 'NOT_EQUAL': self.convert_not_equal,
'ZEROS_LIKE': self.convert_zeros_like,
'REDUCE_MIN': self._convert_reduce_min,
'REDUCE_MAX': self._convert_reduce_max,
@@ -690,7 +695,7 @@ class OperatorConverter(object):
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized sub operator is not supported yet.')
+ 'TFlite quantized SUB operator is not supported yet.')
return self._convert_elemwise(_op.subtract, op)
def convert_mul(self, op):
@@ -705,38 +710,43 @@ class OperatorConverter(object):
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized div operator is not supported yet.')
+ 'TFlite quantized DIV operator is not supported yet.')
return self._convert_elemwise(_op.divide, op)
def convert_pow(self, op):
+ """Convert TFLite POW"""
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized pow operator is not supported yet.')
+ 'TFlite quantized POW operator is not supported yet.')
return self._convert_elemwise(_op.power, op)
def convert_maximum(self, op):
+ """Convert TFLite MAXIMUM"""
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized maximum operator is not supported yet.')
+ 'TFlite quantized MAXIMUM operator is not supported yet.')
return self._convert_elemwise(_op.maximum, op)
def convert_minimum(self, op):
+ """Convert TFLite MINIMUM"""
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized minimum operator is not supported yet.')
+ 'TFlite quantized MINIMUM operator is not supported yet.')
return self._convert_elemwise(_op.minimum, op)
def convert_greater(self, op):
+ """Convert TFLite GREATER"""
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
- 'TFlite quantized greater operator is not supported yet.')
+ 'TFlite quantized GREATER operator is not supported yet.')
return self._convert_elemwise(_op.greater, op)
def convert_squared_difference(self, op):
+ """Convert TFLite SQUARED DIFFERENCE"""
# Check if the input tensor is quantized, call QNN op
if self.is_quantized(op):
raise tvm.error.OpNotImplemented(
@@ -747,6 +757,41 @@ class OperatorConverter(object):
out = _op.power(difference, relay.const(2, exp_type))
return out
+ def convert_greater_equal(self, op):
+ """Convert TFLite GREATER_EQUAL"""
+ if self.is_quantized(op):
+ raise tvm.error.OpNotImplemented(
+ 'TFlite quantized GREATER_EQUAL operator is not supported
yet.')
+ return self._convert_elemwise(_op.greater_equal, op)
+
+ def convert_less(self, op):
+ """Convert TFLite LESS"""
+ if self.is_quantized(op):
+ raise tvm.error.OpNotImplemented(
+ 'TFlite quantized LESS operator is not supported yet.')
+ return self._convert_elemwise(_op.less, op)
+
+ def convert_less_equal(self, op):
+ """Convert TFLite LESS_EQUAL"""
+ if self.is_quantized(op):
+ raise tvm.error.OpNotImplemented(
+ 'TFlite quantized LESS_EQUAL operator is not supported yet.')
+ return self._convert_elemwise(_op.less_equal, op)
+
+ def convert_equal(self, op):
+ """Convert TFLite EQUAL"""
+ if self.is_quantized(op):
+ raise tvm.error.OpNotImplemented(
+ 'TFlite quantized EQUAL operator is not supported yet.')
+ return self._convert_elemwise(_op.equal, op)
+
+ def convert_not_equal(self, op):
+ """Convert TFLite NOT_EQUAL"""
+ if self.is_quantized(op):
+ raise tvm.error.OpNotImplemented(
+ 'TFlite quantized NOT_EQUAL operator is not supported yet.')
+ return self._convert_elemwise(_op.not_equal, op)
+
def convert_zeros_like(self, op):
"""Convert TFLite ZEROS LIKE"""
try:
diff --git a/tests/python/frontend/tflite/test_forward.py
b/tests/python/frontend/tflite/test_forward.py
index b7550f4..9835bfc 100644
--- a/tests/python/frontend/tflite/test_forward.py
+++ b/tests/python/frontend/tflite/test_forward.py
@@ -863,7 +863,41 @@ def _test_minimum(data):
def _test_greater(data):
""" One iteration of greater """
return _test_elemwise(math_ops.greater, data)
+#######################################################################
+# Greater_equal
+# -------------
+
+def _test_greater_equal(data):
+ """ One iteration of greater_equal """
+ return _test_elemwise(math_ops.greater_equal, data)
+#######################################################################
+# Less
+# ----
+
+def _test_less(data):
+ """ One iteration of less """
+ return _test_elemwise(math_ops.less, data)
+#######################################################################
+# Less_equal
+# ----------
+
+def _test_less_equal(data):
+ """ One iteration of less_equal """
+ return _test_elemwise(math_ops.less_equal, data)
+#######################################################################
+# Equal
+# -----
+
+def _test_equal(data):
+ """ One iteration of equal """
+ return _test_elemwise(math_ops.equal, data)
+#######################################################################
+# Not_equal
+# ---------
+def _test_not_equal(data):
+ """ One iteration of not_equal"""
+ return _test_elemwise(math_ops.not_equal, data)
#######################################################################
# Squared_difference
# ------------------
@@ -915,6 +949,11 @@ def test_all_elemwise():
_test_forward_elemwise(_test_minimum)
_test_forward_elemwise(_test_greater)
_test_forward_elemwise(_test_squared_difference)
+ _test_forward_elemwise(_test_greater_equal)
+ _test_forward_elemwise(_test_less)
+ _test_forward_elemwise(_test_less_equal)
+ _test_forward_elemwise(_test_equal)
+ _test_forward_elemwise(_test_not_equal)
#######################################################################
# Zeros like