For the complete documentation index, see llms.txt. Markdown versions of all pages are available by appending .md to any URL (e.g. /max/get-started.md).
Mojo struct
BlockwiseFP8TileStorage
struct BlockwiseFP8TileStorage[a_type: DType, b_type: DType, c_type: DType, a_scales_type: DType, a_shape: IndexList[2], b_shape: IndexList[2], c_dim0: Int, c_dim1: Int, a_scales_shape: IndexList[2], num_pipeline_stages: Int, num_output_stages: Int]
Storage for blockwise FP8 matmul tiles (A, B, C, A-scales).
Single source of truth for blockwise FP8 tile arrays and storage. B-scales are read directly from global memory during epilogue.
All tiles use TileTensor natively. LayoutTensor conversion is kept for SMemEpilogueWriter compatibility.
IMPORTANT: Field order preserves SMEM layout compatibility: a, b, c, a_scales.
Parametersβ
- βa_type (
DType): Data type for A matrix tiles. - βb_type (
DType): Data type for B matrix tiles. - βc_type (
DType): Data type for C matrix tiles. - βa_scales_type (
DType): Data type for A scale tiles. - βa_shape (
IndexList[2]): Tile shape for A tiles as (rows, cols). - βb_shape (
IndexList[2]): Tile shape for B tiles as (rows, cols). - βc_dim0 (
Int): First dimension for C tiles (OutputM). - βc_dim1 (
Int): Second dimension for C tiles (OutputN). - βa_scales_shape (
IndexList[2]): Tile shape for A scale tiles as (rows, cols). - βnum_pipeline_stages (
Int): Number of input pipeline stages. - βnum_output_stages (
Int): Number of output pipeline stages.
Fieldsβ
- βa_tiles_storage (
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].ATileArray.Storage): - βb_tiles_storage (
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].BTileArray.Storage): - βc_tiles_storage (
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].CTileArray.Storage): - βa_scales_tiles_storage (
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].AScalesTileArray.Storage):
Implemented traitsβ
AnyType,
ImplicitlyDestructible
comptime membersβ
AScalesTileArrayβ
comptime AScalesTileArray = SMemTileArray2DRowMajor[a_scales_type, a_scales_shape[0], a_scales_shape[1], num_pipeline_stages]
ATileArrayβ
comptime ATileArray = SMemTileArray2D[a_type, a_shape[0], a_shape[1], num_pipeline_stages]
BTileArrayβ
comptime BTileArray = SMemTileArray2D[b_type, b_shape[0], b_shape[1], num_pipeline_stages]
c_tile_layoutβ
comptime c_tile_layout = Layout.row_major(c_dim0, c_dim1)
CTileArrayβ
comptime CTileArray = SMemTileArray2DRowMajor[c_type, c_dim0, c_dim1, num_output_stages]
Methodsβ
a_tilesβ
a_tiles(ref[AddressSpace._value] self) -> BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].ATileArray
Get A tile array accessor.
Returns:
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].ATileArray
b_tilesβ
b_tiles(ref[AddressSpace._value] self) -> BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].BTileArray
Get B tile array accessor.
Returns:
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].BTileArray
c_tilesβ
c_tiles(ref[AddressSpace._value] self) -> BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].CTileArray
Get C tile array accessor.
Returns:
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].CTileArray
a_scales_tilesβ
a_scales_tiles(ref[AddressSpace._value] self) -> BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].AScalesTileArray
Get A-scales tile array accessor.
Returns:
BlockwiseFP8TileStorage[a_type, b_type, c_type, a_scales_type, a_shape, b_shape, c_dim0, c_dim1, a_scales_shape, num_pipeline_stages, num_output_stages].AScalesTileArray
Was this page helpful?
Thank you! We'll create more content like this.
Thank you for helping us improve!