pub struct TilingScheme {
pub tile_size: TileSize,
pub partition_size: PartitionSize,
pub stage_size: StageSize,
pub global_partition_size: GlobalPartitionSize,
}
Expand description
Complete tiling configuration for a matmul. Encodes all structural information needed to compute tiling shapes and counts.
Fields§
§tile_size: TileSize
§partition_size: PartitionSize
§stage_size: StageSize
§global_partition_size: GlobalPartitionSize
Implementations§
Source§impl TilingScheme
impl TilingScheme
Sourcepub fn builder() -> TilingSchemeBuilder
pub fn builder() -> TilingSchemeBuilder
Create a builder for TilingScheme
Source§impl TilingScheme
impl TilingScheme
pub fn stage_partitions_in_stage_m(&self) -> u32
pub fn stage_partitions_in_stage_n(&self) -> u32
pub fn stage_partitions_in_stage_k(&self) -> u32
pub fn stage_partitions_in_stage_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn stage_partitions_in_stage_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn stage_partitions_in_stage_mk(&self) -> u32
pub fn stage_partitions_in_stage_nk(&self) -> u32
pub fn stage_partitions_in_stage_mn(&self) -> u32
pub fn stage_partitions_in_stage<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_m(&self) -> u32
pub fn tiles_in_stage_n(&self) -> u32
pub fn tiles_in_stage_k(&self) -> u32
pub fn tiles_in_stage_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_mk(&self) -> u32
pub fn tiles_in_stage_nk(&self) -> u32
pub fn tiles_in_stage_mn(&self) -> u32
pub fn tiles_in_stage<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_m(&self) -> u32
pub fn elements_in_stage_n(&self) -> u32
pub fn elements_in_stage_k(&self) -> u32
pub fn elements_in_stage_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_mk(&self) -> u32
pub fn elements_in_stage_nk(&self) -> u32
pub fn elements_in_stage_mn(&self) -> u32
pub fn elements_in_stage<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_partition_m(&self) -> u32
pub fn tiles_in_stage_partition_n(&self) -> u32
pub fn tiles_in_stage_partition_k(&self) -> u32
pub fn tiles_in_stage_partition_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_partition_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn tiles_in_stage_partition_mk(&self) -> u32
pub fn tiles_in_stage_partition_nk(&self) -> u32
pub fn tiles_in_stage_partition_mn(&self) -> u32
pub fn tiles_in_stage_partition<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_partition_m(&self) -> u32
pub fn elements_in_stage_partition_n(&self) -> u32
pub fn elements_in_stage_partition_k(&self) -> u32
pub fn elements_in_stage_partition_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_partition_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_stage_partition_mk(&self) -> u32
pub fn elements_in_stage_partition_nk(&self) -> u32
pub fn elements_in_stage_partition_mn(&self) -> u32
pub fn elements_in_stage_partition<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_tile_m(&self) -> u32
pub fn elements_in_tile_n(&self) -> u32
pub fn elements_in_tile_k(&self) -> u32
pub fn elements_in_tile_row<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_tile_col<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_tile_mk(&self) -> u32
pub fn elements_in_tile_nk(&self) -> u32
pub fn elements_in_tile_mn(&self) -> u32
pub fn elements_in_tile<I: Into<Ident>>(&self, ident: I) -> u32
pub fn elements_in_global_partition_m(&self) -> u32
pub fn elements_in_global_partition_n(&self) -> u32
pub fn tiles_in_global_partition_m(&self) -> u32
pub fn tiles_in_global_partition_n(&self) -> u32
pub fn stage_partitions_in_global_partition_m(&self) -> u32
pub fn stage_partitions_in_global_partition_n(&self) -> u32
pub fn stages_in_global_partition_m(&self) -> u32
pub fn stages_in_global_partition_n(&self) -> u32
Trait Implementations§
Source§impl Clone for TilingScheme
impl Clone for TilingScheme
Source§fn clone(&self) -> TilingScheme
fn clone(&self) -> TilingScheme
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for TilingScheme
impl Debug for TilingScheme
Source§impl Hash for TilingScheme
impl Hash for TilingScheme
Source§impl PartialEq for TilingScheme
impl PartialEq for TilingScheme
impl Copy for TilingScheme
impl Eq for TilingScheme
impl StructuralPartialEq for TilingScheme
Auto Trait Implementations§
impl Freeze for TilingScheme
impl RefUnwindSafe for TilingScheme
impl Send for TilingScheme
impl Sync for TilingScheme
impl Unpin for TilingScheme
impl UnwindSafe for TilingScheme
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.