DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation > Struct Template Reference

DeviceContractionMultipleABD&lt; NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation &gt; Struct Template Reference#

Composable Kernel: ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation > Struct Template Reference
ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation > Struct Template Referenceabstract

#include <device_contraction_multiple_abd.hpp>

Inheritance diagram for ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >:
ck::tensor_operation::device::BaseOperator ck::tensor_operation::device::DeviceContractionMultipleABD_Xdl_CShuffle< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, AccDataType, CShuffleDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation, GemmSpec, NumGemmKPrefetchStage, BlockSize, MPerBlock, NPerBlock, KPerBlock, AK1, BK1, MPerXDL, NPerXDL, MXdlPerWave, NXdlPerWave, ABlockTransferThreadClusterLengths_AK0_M_AK1, ABlockTransferThreadClusterArrangeOrder, ABlockTransferSrcAccessOrder, ABlockTransferSrcVectorDim, ABlockTransferSrcScalarPerVector, ABlockTransferDstScalarPerVector_AK1, ABlockLdsExtraM, BBlockTransferThreadClusterLengths_BK0_N_BK1, BBlockTransferThreadClusterArrangeOrder, BBlockTransferSrcAccessOrder, BBlockTransferSrcVectorDim, BBlockTransferSrcScalarPerVector, BBlockTransferDstScalarPerVector_BK1, BBlockLdsExtraN, CShuffleMXdlPerWavePerShuffle, CShuffleNXdlPerWavePerShuffle, CDEBlockTransferClusterLengths_MBlock_MPerBlock_NBlock_NPerBlock, CDEBlockTransferScalarPerVector_NPerBlock, LoopSched, PipelineVer >

Public Member Functions

virtual std::unique_ptr< BaseArgumentMakeArgumentPointer (std::array< const void *, NumATensor > p_as, std::array< const void *, NumBTensor > p_bs, std::array< const void *, NumDTensor > p_ds, void *p_e, const std::array< std::vector< index_t >, NumATensor > &a_ms_ks_lengths, const std::array< std::vector< index_t >, NumATensor > &a_ms_ks_strides, const std::array< std::vector< index_t >, NumBTensor > &b_ns_ks_lengths, const std::array< std::vector< index_t >, NumBTensor > &b_ns_ks_strides, const std::array< std::vector< index_t >, NumDTensor > &d_ms_ns_lengths, const std::array< std::vector< index_t >, NumDTensor > &d_ms_ns_strides, const std::vector< index_t > &e_ms_ns_length, const std::vector< index_t > &e_ms_ns_stride, AElementwiseOperation a_element_op, BElementwiseOperation b_element_op, CDEElementwiseOperation cde_element_op)=0
virtual std::unique_ptr< BaseInvokerMakeInvokerPointer ()=0
Public Member Functions inherited from ck::tensor_operation::device::BaseOperator
 BaseOperator ()=default
 BaseOperator (const BaseOperator &)=default
BaseOperatoroperator= (const BaseOperator &)=default
virtual bool IsSupportedArgument (const BaseArgument *)
virtual std::string GetTypeString () const
virtual std::string GetInstanceString () const
virtual std::string GetTypeIdName () const
virtual std::optional< std::string > GetObjectName () const
virtual std::optional< std::string > GetTemplateInfo () const
virtual std::string GetTypeIdHashCode () const
virtual size_t GetWorkSpaceSize (const BaseArgument *) const
virtual void SetWorkSpacePointer (BaseArgument *p_arg, void *p_workspace, const StreamConfig &=StreamConfig{}) const
virtual ~BaseOperator ()

Static Public Attributes

static constexpr index_t NumATensor = AsDataType::Size()
static constexpr index_t NumBTensor = BsDataType::Size()
static constexpr index_t NumDTensor = DsDataType::Size()

Member Function Documentation

◆ MakeArgumentPointer()

template<index_t NumDimM, index_t NumDimN, index_t NumDimK, typename AsDataType, typename BsDataType, typename DsDataType, typename EDataType, typename AElementwiseOperation, typename BElementwiseOperation, typename CDEElementwiseOperation>
virtual std::unique_ptr< BaseArgument > ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >::MakeArgumentPointer ( std::array< const void *, NumATensor > p_as,
std::array< const void *, NumBTensor > p_bs,
std::array< const void *, NumDTensor > p_ds,
void * p_e,
const std::array< std::vector< index_t >, NumATensor > & a_ms_ks_lengths,
const std::array< std::vector< index_t >, NumATensor > & a_ms_ks_strides,
const std::array< std::vector< index_t >, NumBTensor > & b_ns_ks_lengths,
const std::array< std::vector< index_t >, NumBTensor > & b_ns_ks_strides,
const std::array< std::vector< index_t >, NumDTensor > & d_ms_ns_lengths,
const std::array< std::vector< index_t >, NumDTensor > & d_ms_ns_strides,
const std::vector< index_t > & e_ms_ns_length,
const std::vector< index_t > & e_ms_ns_stride,
AElementwiseOperation a_element_op,
BElementwiseOperation b_element_op,
CDEElementwiseOperation cde_element_op )
pure virtual

◆ MakeInvokerPointer()

template<index_t NumDimM, index_t NumDimN, index_t NumDimK, typename AsDataType, typename BsDataType, typename DsDataType, typename EDataType, typename AElementwiseOperation, typename BElementwiseOperation, typename CDEElementwiseOperation>
virtual std::unique_ptr< BaseInvoker > ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >::MakeInvokerPointer ( )
pure virtual

Member Data Documentation

◆ NumATensor

template<index_t NumDimM, index_t NumDimN, index_t NumDimK, typename AsDataType, typename BsDataType, typename DsDataType, typename EDataType, typename AElementwiseOperation, typename BElementwiseOperation, typename CDEElementwiseOperation>
index_t ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >::NumATensor = AsDataType::Size()
staticconstexpr

◆ NumBTensor

template<index_t NumDimM, index_t NumDimN, index_t NumDimK, typename AsDataType, typename BsDataType, typename DsDataType, typename EDataType, typename AElementwiseOperation, typename BElementwiseOperation, typename CDEElementwiseOperation>
index_t ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >::NumBTensor = BsDataType::Size()
staticconstexpr

◆ NumDTensor

template<index_t NumDimM, index_t NumDimN, index_t NumDimK, typename AsDataType, typename BsDataType, typename DsDataType, typename EDataType, typename AElementwiseOperation, typename BElementwiseOperation, typename CDEElementwiseOperation>
index_t ck::tensor_operation::device::DeviceContractionMultipleABD< NumDimM, NumDimN, NumDimK, AsDataType, BsDataType, DsDataType, EDataType, AElementwiseOperation, BElementwiseOperation, CDEElementwiseOperation >::NumDTensor = DsDataType::Size()
staticconstexpr

The documentation for this struct was generated from the following file: