Mojo struct
TileScheduler
@register_passable(trivial)
struct TileScheduler[M: Int, tile_shape: IndexList[3], cluster: IndexList[3] = Index(1, 1, 1), cta_group: Int = 1, swizzle: Bool = False]
Fields
- num_active_experts (
Int
): - group_offsets (
NDBuffer[DType.uint32, 1, MutableAnyOrigin]
): - current_iter (
Int32
): - current_group_idx (
UInt32
): - current_n_cumsum (
UInt32
): - block_idx_start (
UInt32
):
Implemented traits
AnyType
,
Copyable
,
ImplicitlyCopyable
,
Movable
,
UnknownDestructibility
Aliases
__copyinit__is_trivial
alias __copyinit__is_trivial = True
__del__is_trivial
alias __del__is_trivial = True
__moveinit__is_trivial
alias __moveinit__is_trivial = True
div_block_n
alias div_block_n = FastDiv[DType.uint32]((tile_shape.__getitem__[3, DType.int64, Int](1) * cta_group))
kNum1DBlocksPerGroup
alias kNum1DBlocksPerGroup = 16
num_m_blocks
alias num_m_blocks = SIMD[DType.uint32, 1](ceildiv(M, tile_shape.__getitem__[3, DType.int64, Int](0)))
tile_n
alias tile_n = (tile_shape.__getitem__[3, DType.int64, Int](1) * cta_group)
Methods
__init__
__init__(num_active_experts: Int, group_offsets: NDBuffer[DType.uint32, 1, MutableAnyOrigin]) -> Self
fetch_next_work
fetch_next_work(mut self) -> WorkInfo
Returns:
WorkInfo
Was this page helpful?
Thank you! We'll create more content like this.
Thank you for helping us improve!