Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Schedule] Allowed typing.Tuple in tir.schedule._type_checker #11289

Merged
merged 5 commits into from
May 20, 2022

Conversation

Lunderberg
Copy link
Contributor

Previously, typing.Tuple annotations could not be used with tir.schedule._type_checker.type_checked annotations. This allows Tuple type annotations to be type-checked.

Previously, `typing.Tuple` annotations could not be used with
`tir.schedule._type_checker.type_checked` annotations.  This allows
`Tuple` type annotations to be type-checked.
@junrushao
Copy link
Member

Thanks for improving the type checker! Maybe at some time point we could together propose to lift this to top-level TVM utility with an RFC :-)

Directly interacting with a type object would otherwise cause some
false positives.
This gives a better error message and plays nicely with _type2str,
since `typing.Any` doesn't have a `__name__` field.
@Lunderberg Lunderberg marked this pull request as ready for review May 19, 2022 13:18
@Lunderberg
Copy link
Contributor Author

@vinx13 @junrushao1994 CI passing, and ready for review.

@vinx13 vinx13 merged commit 72a5219 into apache:main May 20, 2022
@Lunderberg Lunderberg deleted the type_check_tuple branch May 20, 2022 17:28
Lunderberg added a commit to Lunderberg/tvm that referenced this pull request May 20, 2022
Disabled while waiting for apache#11289,
which was required for the `Tuple` argument.
vinx13 pushed a commit that referenced this pull request May 26, 2022
* [TIR][Schedule] Added Schedule.transform_layout_sugared

* [TE][TIR] Reduced duplication in TE/TIR layout transformations

Previously, the implementations of `tir.IndexMap.from_func` and
`te.Stage.transform_layout` had significant duplication to handle
argument parsing.  This commit extracts the shared logic into
`tir.IndexMap`.

* Enabled *args in Schedule.transform_layout_sugared

* Fix lint error

* Allow Schedule.transform_layout_sugared to set axis separators

* Merged transform_layout_sugared functionality into transform_layout

* Fix lint errors

* Fix lint error

* Fixed docstring errors

* Updated/tested TransformatLayoutTraits::UnpackedAsPython

* Disabled exec-used check for running trace.as_python()

* Updated SetAxisSeparatorTraits::UnpackedAsPython

* Updated unit test that was added in merge commit

* Fixed the argument name for TensorizeTraits

This wasn't checked before, but was the only other issue caught by the
updates to verify_trace_roundtrip.

* Re-enable type checks of transform_layout/set_axis_separator

Disabled while waiting for #11289,
which was required for the `Tuple` argument.

* Updated a few additional transform_layout usages from main
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants