sunggg commented on code in PR #14548:
URL: https://github.com/apache/tvm/pull/14548#discussion_r1161814745


##########
python/tvm/relax/transform/legalize_ops/index.py:
##########
@@ -59,3 +60,39 @@ def _strided_slice(bb: BlockBuilder, call: Call) -> Expr:
         call.attrs.axes,
         slice_mode="end",
     )
+
+
+@register_legalize("relax.dynamic_strided_slice")
+def _dynamic_strided_slice(bb: BlockBuilder, call: Call) -> Expr:
+    # 1. Insert shape function
+    output_shape = bb.normalize(
+        bb.call_te(
+            topi.shape_func_dynamic_strided_slice,
+            call.args[0],
+            call.args[1],
+            call.args[2],
+            call.args[3],

Review Comment:
   > Are we introducing a standard API for shape func (like Relay), or is each 
op going to pick any API as it sees fit (like this example)? In the latter case 
I don't see any reason shape funcs need to belong to topi.
   
   The latter case. 
   
   Great point. I put it in TOPI-side because I viewed TOPI as the registry of 
TEs and developers can easily check related implementations in the single file. 
I don't have any strong preference here, so I'm open to hear what folks prefer. 
 



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to