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: GlobalPartitionSizeImplementations§
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<StageIdent>>( &self, ident: I, ) -> u32
pub fn stage_partitions_in_stage_col<I: Into<StageIdent>>( &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<StageIdent>>(&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<StageIdent>>(&self, ident: I) -> u32
pub fn tiles_in_stage_col<I: Into<StageIdent>>(&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<StageIdent>>(&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<StageIdent>>(&self, ident: I) -> u32
pub fn elements_in_stage_col<I: Into<StageIdent>>(&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<StageIdent>>(&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<StageIdent>>(&self, ident: I) -> u32
pub fn tiles_in_stage_partition_col<I: Into<StageIdent>>(&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<StageIdent>>(&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<StageIdent>>( &self, ident: I, ) -> u32
pub fn elements_in_stage_partition_col<I: Into<StageIdent>>( &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<StageIdent>>(&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<StageIdent>>(&self, ident: I) -> u32
pub fn elements_in_tile_col<I: Into<StageIdent>>(&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<StageIdent>>(&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.