UnitMatmulFamily

Struct UnitMatmulFamily 

Source
pub struct UnitMatmulFamily<TM: TileMatmulFamily, StageIn: StageFamily, StageAcc: StageFamily> { /* private fields */ }
Expand description

Unit Matmul family for any precision

Trait Implementations§

Source§

impl<TM: TileMatmulFamily<LhsTile = StageIn::TileKind, RhsTile = StageIn::TileKind, AccTile = StageAcc::TileKind, OutTile = Strided>, StageIn: StageFamily, StageAcc: StageFamily> StageMatmulFamily for UnitMatmulFamily<TM, StageIn, StageAcc>

Source§

type LhsStage = StageIn

Stage family for Lhs
Source§

type RhsStage = StageIn

Stage family for Rhs
Source§

type AccStage = StageAcc

Stage family for Acc
Source§

type OutStage = PartitionedStageFamily

Stage family for Out
Source§

type Matmul<MP: MatmulPrecision, TL: TilingLayout, TR: TilingLayout, TA: TilingLayout, TO: TilingLayout> = PartitionedStageMatmul<MP, <TM as TileMatmulFamily>::Matmul<<<MP as MatmulPrecision>::Lhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Rhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Acc as MatrixPrecision>::Register>, <StageIn as StageFamily>::Stage<<<<MP as MatmulSpec>::Precision as MatmulPrecision>::Lhs as MatrixPrecision>::Stage, TL>, <StageIn as StageFamily>::Stage<<<<MP as MatmulSpec>::Precision as MatmulPrecision>::Rhs as MatrixPrecision>::Stage, TR>, <StageAcc as StageFamily>::Stage<<<<MP as MatmulSpec>::Precision as MatmulPrecision>::Acc as MatrixPrecision>::Stage, TA>, PartitionedStage<<<<MP as MatmulSpec>::Precision as MatmulPrecision>::Acc as MatrixPrecision>::Stage>, UnitPartitioner, UnitPartitionedStageConfig<<<TM as TileMatmulFamily>::Matmul<<<MP as MatmulPrecision>::Lhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Rhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Acc as MatrixPrecision>::Register> as TileMatmul<<<MP as MatmulPrecision>::Lhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Rhs as MatrixPrecision>::Register, <<MP as MatmulPrecision>::Acc as MatrixPrecision>::Register>>::Config>>

The specific [TileMatmul] implementation associated with this family.
Source§

type Config = UnitPartitionedStageConfig<<TM as TileMatmulFamily>::Config>

The configuration type associated with this matmul family.
Source§

fn setup<MP: MatmulPrecision, R: Runtime>( client: &ComputeClient<R::Server>, problem: &MatmulProblem, selection: &MatmulSelection, line_sizes: &MatmulLineSizes, num_stages: NumStages, max_global_readers: Option<MaxGlobalReaderPlanes>, ordered: bool, ) -> Result<Self::Config, MatmulSetupError>

Constructs the configuration based on the matmul problem, selection, line sizes, number of stages, maximum of tasks per plane, and whether the algorithm is an ordered variant Read more
Source§

fn filter_line_sizes( available_line_sizes: AvailableLineSizes, ) -> AvailableLineSizes

Filters out line sizes that are incompatible with this matmul family. Read more

Auto Trait Implementations§

§

impl<TM, StageIn, StageAcc> Freeze for UnitMatmulFamily<TM, StageIn, StageAcc>

§

impl<TM, StageIn, StageAcc> RefUnwindSafe for UnitMatmulFamily<TM, StageIn, StageAcc>
where TM: RefUnwindSafe, StageIn: RefUnwindSafe, StageAcc: RefUnwindSafe,

§

impl<TM, StageIn, StageAcc> Send for UnitMatmulFamily<TM, StageIn, StageAcc>

§

impl<TM, StageIn, StageAcc> Sync for UnitMatmulFamily<TM, StageIn, StageAcc>

§

impl<TM, StageIn, StageAcc> Unpin for UnitMatmulFamily<TM, StageIn, StageAcc>
where TM: Unpin, StageIn: Unpin, StageAcc: Unpin,

§

impl<TM, StageIn, StageAcc> UnwindSafe for UnitMatmulFamily<TM, StageIn, StageAcc>
where TM: UnwindSafe, StageIn: UnwindSafe, StageAcc: UnwindSafe,

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> 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, 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