StridedTilingLayout

Struct StridedTilingLayout 

Source
pub struct StridedTilingLayout {}
Expand description

Tiles follow a strided layout that often mirrors global memory layout. Not all tiles are contiguous in shared memory, but mapping is more direct.

Implementations§

Source§

impl StridedTilingLayout

Source

pub fn nth_slice<ES: Numeric>( stage: &mut StridedStage<ES, Self>, nth: u32, config: StageMemoryConfig, ) -> SliceMut<Line<ES>>

Returns the nth slice of the stage

Source

pub fn __expand_nth_slice<ES: Numeric>( scope: &mut Scope, stage: <StridedStage<ES, Self> as CubeType>::ExpandType, nth: <u32 as CubeType>::ExpandType, config: StageMemoryConfig, ) -> <SliceMut<Line<ES>> as CubeType>::ExpandType

Trait Implementations§

Source§

impl<IP: MatrixPrecision> AsyncLoadingJob<IP, StridedTilingLayout> for AsynFullMaximizeSliceLengthJob

Source§

fn execute_task<CM: CopyMechanism, G: GlobalConfig>( this: &mut Self, task_id: u32, tensor_reader: &GlobalIterator<Line<IP::Global>>, stage: &mut StridedStage<IP::Stage, StridedTilingLayout>, mechanism: &CM, config: G, )

Execute the task_idth loading task
Source§

fn task_count(this: &Self) -> u32

Get the number of tasks
Source§

fn __expand_execute_task<CM: CopyMechanism, G: GlobalConfig>( scope: &mut Scope, this: <Self as CubeType>::ExpandType, task_id: <u32 as CubeType>::ExpandType, tensor_reader: <GlobalIterator<Line<IP::Global>> as CubeType>::ExpandType, stage: <StridedStage<IP::Stage, StridedTilingLayout> as CubeType>::ExpandType, mechanism: <CM as CubeType>::ExpandType, config: G, ) -> <() as CubeType>::ExpandType

Source§

fn __expand_task_count( scope: &mut Scope, this: <Self as CubeType>::ExpandType, ) -> u32

Source§

impl<IP: MatrixPrecision> AsyncLoadingJob<IP, StridedTilingLayout> for AsyncFullCooperativeJob

Source§

fn execute_task<CM: CopyMechanism, G: GlobalConfig>( this: &mut Self, task_id: u32, global_iter: &GlobalIterator<Line<IP::Global>>, stage: &mut StridedStage<IP::Stage, StridedTilingLayout>, mechanism: &CM, config: G, )

Execute the task_idth loading task
Source§

fn task_count(this: &Self) -> u32

Get the number of tasks
Source§

fn __expand_execute_task<CM: CopyMechanism, G: GlobalConfig>( scope: &mut Scope, this: <Self as CubeType>::ExpandType, task_id: <u32 as CubeType>::ExpandType, global_iter: <GlobalIterator<Line<IP::Global>> as CubeType>::ExpandType, stage: <StridedStage<IP::Stage, StridedTilingLayout> as CubeType>::ExpandType, mechanism: <CM as CubeType>::ExpandType, config: G, ) -> <() as CubeType>::ExpandType

Source§

fn __expand_task_count( scope: &mut Scope, this: <Self as CubeType>::ExpandType, ) -> u32

Source§

impl<IP: MatrixPrecision> AsyncLoadingJob<IP, StridedTilingLayout> for AsyncFullMaximizeUnitCountJob

Source§

fn execute_task<CM: CopyMechanism, G: GlobalConfig>( this: &mut Self, _task_id: u32, global_iter: &GlobalIterator<Line<IP::Global>>, stage: &mut StridedStage<IP::Stage, StridedTilingLayout>, mechanism: &CM, config: G, )

Execute the task_idth loading task
Source§

fn task_count(_this: &Self) -> u32

Get the number of tasks
Source§

fn __expand_execute_task<CM: CopyMechanism, G: GlobalConfig>( scope: &mut Scope, this: <Self as CubeType>::ExpandType, _task_id: <u32 as CubeType>::ExpandType, global_iter: <GlobalIterator<Line<IP::Global>> as CubeType>::ExpandType, stage: <StridedStage<IP::Stage, StridedTilingLayout> as CubeType>::ExpandType, mechanism: <CM as CubeType>::ExpandType, config: G, ) -> <() as CubeType>::ExpandType

Source§

fn __expand_task_count( scope: &mut Scope, _this: <Self as CubeType>::ExpandType, ) -> u32

Source§

impl<IP: MatrixPrecision> AsyncLoadingJob<IP, StridedTilingLayout> for AsyncPartialMaximizeSliceLengthJob

Source§

fn execute_task<CM: CopyMechanism, G: GlobalConfig>( this: &mut Self, task_id: u32, global_iter: &GlobalIterator<Line<IP::Global>>, stage: &mut StridedStage<IP::Stage, StridedTilingLayout>, mechanism: &CM, config: G, )

Execute the task_idth loading task
Source§

fn task_count(this: &Self) -> u32

Get the number of tasks
Source§

fn __expand_execute_task<CM: CopyMechanism, G: GlobalConfig>( scope: &mut Scope, this: <Self as CubeType>::ExpandType, task_id: <u32 as CubeType>::ExpandType, global_iter: <GlobalIterator<Line<IP::Global>> as CubeType>::ExpandType, stage: <StridedStage<IP::Stage, StridedTilingLayout> as CubeType>::ExpandType, mechanism: <CM as CubeType>::ExpandType, config: G, ) -> <() as CubeType>::ExpandType

Source§

fn __expand_task_count( scope: &mut Scope, this: <Self as CubeType>::ExpandType, ) -> u32

Source§

impl Clone for StridedTilingLayout

Source§

fn clone(&self) -> StridedTilingLayout

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<IP: MatrixPrecision> LoadingJob<IP, StridedTilingLayout> for SyncFullStridedJob

Source§

fn execute_task<G: GlobalConfig>( this: &mut Self, task_id: u32, global_iter: &GlobalIterator<Line<IP::Global>>, stage: &mut StridedStage<IP::Stage, StridedTilingLayout>, config: G, )

Execute the task_idth loading task
Source§

fn task_count(this: &Self) -> u32

Get the number of tasks
Source§

fn __expand_execute_task<G: GlobalConfig>( scope: &mut Scope, this: <Self as CubeType>::ExpandType, task_id: u32, global_iter: <GlobalIterator<Line<IP::Global>> as CubeType>::ExpandType, stage: <StridedStage<IP::Stage, StridedTilingLayout> as CubeType>::ExpandType, config: G, ) -> <() as CubeType>::ExpandType

Source§

fn __expand_task_count( scope: &mut Scope, this: <Self as CubeType>::ExpandType, ) -> u32

Source§

impl TilingLayout for StridedTilingLayout

Source§

fn get_tile<ES: Numeric>( stage: &StridedStage<ES, Self>, tile: Coords2d, _buffer_index: u32, _ident: StageIdent, config: StageMemoryConfig, ) -> StridedTile<ES>

Returns the tile at shared memory coordinates
Source§

fn __expand_get_tile<ES: Numeric>( scope: &mut Scope, stage: <StridedStage<ES, Self> as CubeType>::ExpandType, tile: <Coords2d as CubeType>::ExpandType, _buffer_index: <u32 as CubeType>::ExpandType, _ident: StageIdent, config: StageMemoryConfig, ) -> <StridedTile<ES> as CubeType>::ExpandType

Source§

impl TilingValidation for StridedTilingLayout

Source§

impl Copy for StridedTilingLayout

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V