Skip to content

[TIR][Schedule] Transform layout#10538

Merged
vinx13 merged 11 commits intoapache:mainfrom
vinx13:feat/transform_layout
Mar 23, 2022
Merged

[TIR][Schedule] Transform layout#10538
vinx13 merged 11 commits intoapache:mainfrom
vinx13:feat/transform_layout

Conversation

@vinx13
Copy link
Copy Markdown
Member

@vinx13 vinx13 commented Mar 8, 2022

This PR added a schedule primitive transform_layout in TIR. It is similar to the one in TE as discussed in RFC.

cc @junrushao1994 @Lunderberg @jinhongyii @spectrometerHBH

Comment thread python/tvm/tir/schedule/schedule.py
Comment thread python/tvm/tir/schedule/schedule.py
Copy link
Copy Markdown
Member

@Hzfengsy Hzfengsy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall LGTM. Thanks @vinx13

Comment thread tests/python/unittest/test_tir_schedule_transform_layout.py Outdated
@github-actions github-actions Bot requested a review from junrushao March 10, 2022 00:42
@vinx13 vinx13 force-pushed the feat/transform_layout branch from fc3a9cc to b4f58df Compare March 12, 2022 00:52
Copy link
Copy Markdown
Contributor

@Lunderberg Lunderberg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fantastic work, and I really like that layout transforms will be usable on both TE and TIR schedules. Just a few questions/comments, mostly on user interactions.

Comment thread include/tvm/tir/schedule/schedule.h
Comment thread python/tvm/tir/function.py Outdated
Comment thread python/tvm/tir/schedule/schedule.py
Comment thread src/tir/ir/index_map.cc
Comment thread src/tir/schedule/primitive/layout_transformation.cc
Comment thread src/tir/schedule/primitive/layout_transformation.cc
Comment thread src/tir/schedule/primitive/layout_transformation.cc
Comment thread tests/python/unittest/test_tir_schedule_transform_layout.py Outdated
@github-actions github-actions Bot requested a review from Lunderberg March 14, 2022 23:51
Comment thread python/tvm/tir/schedule/schedule.py
Comment thread python/tvm/tir/schedule/schedule.py Outdated
@github-actions github-actions Bot requested a review from Lunderberg March 21, 2022 23:59
Copy link
Copy Markdown
Contributor

@Lunderberg Lunderberg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! Thank you for the discussion on the changes.

@github-actions github-actions Bot requested a review from Lunderberg March 22, 2022 20:12
@vinx13 vinx13 force-pushed the feat/transform_layout branch from 0e4ee24 to d82bccf Compare March 22, 2022 23:56
@vinx13 vinx13 merged commit 5679bd2 into apache:main Mar 23, 2022
Comment on lines +76 to +81
class BufferType(enum.IntEnum):
"""Type of buffer in access regions of a block"""

READ = 0
WRITE = 1

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@vinx13 Sorry I'm late and missed the code review. On this particular change, I'm 100% in favor of having enum type on C++ side; However, it could be more to "just use string" on the python side, i.e. use "read" and "write" to indicate BufferType. If you agree with my opinion, would you mind sending a quick patch? Thanks a lot!

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This sounds good to me as well, and would give the same readability benefits at the caller side. I kind of like the enum usage in python as well, since it lets the reader know what options are possible, but that's the less important benefit.

At some point, it would be nice to have a macro to define an enum in C++, along with its value/name mapping and an FFI interface, so that there would be a clear way to handle these.

junrushao pushed a commit that referenced this pull request Mar 24, 2022
…10737)

This is a follow-up of #10538 to use string instead of enum in python side.
pfk-beta pushed a commit to pfk-beta/tvm that referenced this pull request Apr 11, 2022
* [TIR][Schedule] Transform layout

* address commens

* fix

* doc

* Address comments

* remove unused

* Use BufferIndexType enum

* lint

* support *args

* lint

* lint
pfk-beta pushed a commit to pfk-beta/tvm that referenced this pull request Apr 11, 2022
…pache#10737)

This is a follow-up of apache#10538 to use string instead of enum in python side.
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.

4 participants