gemm_pipeline_ag_bg_cr_comp_v6.hpp Source File#
gemm_pipeline_ag_bg_cr_comp_v6.hpp
Go to the documentation of this file.
141 static constexpr index_t GetVectorSizeC() { return Policy::template GetVectorSizeC<Problem>(); }
Definition tile/core/algorithm/cluster_descriptor.hpp:13
remove_cv_t< std::remove_reference_t< T > > remove_cvref_t
Definition type_traits.hpp:21
CK_TILE_DEVICE auto load_tile_with_elementwise(const TileWindow_ &tile_window, ElementWise_ elementwise, number< i_access >={}, bool_constant< oob_conditional_check >={})
Load tile with elementwise function.
Definition load_tile.hpp:41
constant< b > bool_constant
Definition tile/core/numeric/integral_constant.hpp:43
typename detail::detector< nonesuch, void, Op, Args... >::value_t is_detected
Definition type_traits.hpp:67
CK_TILE_DEVICE void tile_elementwise_inout(const InOutElementFunc &inout_element_func, InOutDstrTensors &... inout_dstr_tensors)
Definition tile_elementwise.hpp:23
auto concat(const Ts &... xs) -> std::enable_if_t<!AllConvertibleToStringView< Ts... >, std::string >
Definition concat.hpp:43
CK_TILE_DEVICE void transpose_tile2d(OutTensor &out, const InTensor &in)
Definition transpose_tile.hpp:195
CK_TILE_HOST_DEVICE constexpr auto make_static_distributed_tensor(const StaticTileDistribution &)
Definition static_distributed_tensor.hpp:142
CK_TILE_DEVICE void move_tile_window(null_tile_window< WindowLengths > &, const typename null_tile_window< WindowLengths >::BottomTensorIndex &)
Definition null_tile_window.hpp:95
CK_TILE_HOST_DEVICE constexpr auto make_static_tile_distribution(StaticTileDistributionEncoding_)
Definition tile_distribution.hpp:480
GemmPipelineScheduler
Definition gemm_pipeline_ag_bg_cr_scheduler.hpp:14
@ Intrawave
Definition gemm_pipeline_ag_bg_cr_scheduler.hpp:16
CK_TILE_HOST_DEVICE constexpr details::return_type< D, Ts... > make_array(Ts &&... ts)
Definition tile/core/container/array.hpp:242
CK_TILE_HOST_DEVICE constexpr auto make_tuple(Xs &&... xs)
Definition tile/core/container/tuple.hpp:360
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:16
static CK_TILE_HOST_DEVICE auto TailHandler(const RunFunction &run_func, bool has_hot_loop, TailNumber tail_number)
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:43
static CK_TILE_HOST_DEVICE constexpr auto TransposeC()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:22
static constexpr index_t PrefetchStages
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:17
static constexpr index_t PrefillStages
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:18
static CK_TILE_HOST constexpr TailNumber GetBlockLoopTailNum(index_t num_loop)
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:29
static constexpr index_t HotloopUnroll
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:20
static constexpr index_t GlobalBufferNum
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:19
static CK_TILE_HOST constexpr bool BlockHasHotloop(index_t num_loop)
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:24
CK_TILE_DEVICE auto operator()(const AsDramBlockWindowTmp &a_dram_block_window_tmp, const AElementFunction &a_element_func, const BsDramBlockWindowTmp &b_dram_block_window_tmp, const BElementFunction &b_element_func, index_t num_loop, void *__restrict__ p_smem) const
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:368
static CK_TILE_DEVICE constexpr auto HotLoopScheduler()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:194
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:188
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:89
static constexpr bool HasHotLoop
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:155
static constexpr bool kPadN
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:149
static constexpr auto I0
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:121
static constexpr auto Scheduler
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:157
static constexpr bool kPadM
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:148
static constexpr index_t GetSmemPackB()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:144
static constexpr auto TailNum
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:156
static constexpr index_t BPackedSize
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:115
BaseGemmPipelineAgBgCrCompV6< Problem > Base
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:90
CK_TILE_DEVICE auto operator()(const ADramBlockWindowTmp &a_dram_block_window_tmp, const AElementFunction &a_element_func, const BDramBlockWindowTmp &b_dram_block_window_tmp, const BElementFunction &b_element_func, index_t num_loop, void *__restrict__ p_smem) const
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:755
static constexpr index_t KRepeat
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:146
remove_cvref_t< std::tuple_element_t< 0, BsLayout > > BLayout
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:106
static constexpr auto is_b_load_tr_v
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:160
GemmPipelineAgBgCrImplBase< Problem, Policy > BasePImpl
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:91
static constexpr index_t GetSmemPackA()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:143
static CK_TILE_HOST_DEVICE constexpr auto IsTransposeC()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:181
static constexpr auto is_a_load_tr_v
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:159
remove_cvref_t< typename Problem::AElementWise > AElementWise
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:98
remove_cvref_t< typename Problem::CLayout > CLayout
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:103
static constexpr auto I2
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:123
remove_cvref_t< decltype(Policy::template GetBlockGemm< Problem >())> BlockGemm
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:120
static CK_TILE_HOST_DEVICE constexpr index_t GetSmemSize()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:176
remove_cvref_t< typename Problem::BsLayoutTuple > BsLayout
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:102
remove_cvref_t< typename Problem::BsDataTypeTuple > BsDataType
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:94
static constexpr index_t KPerBlock
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:129
remove_cvref_t< std::tuple_element_t< 0, AsDataType > > ADataType
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:108
static constexpr index_t NumWaveGroups
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:118
remove_cvref_t< typename Problem::BElementWise > BElementWise
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:99
static constexpr auto I1
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:122
CK_TILE_DEVICE auto operator()(const AsDramBlockWindowTmp &a_dram_block_window_tmp, const BsDramBlockWindowTmp &b_dram_block_window_tmp, const index_t num_loop, void *__restrict__ p_smem) const
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:734
remove_cvref_t< typename Problem::AsLayoutTuple > AsLayout
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:101
remove_cvref_t< typename Problem::BlockGemmShape > BlockGemmShape
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:96
static constexpr index_t BlockSize
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:125
static constexpr index_t APackedSize
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:113
static CK_TILE_HOST const std::string GetName()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:162
static constexpr index_t GetVectorSizeA()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:132
static constexpr index_t GetVectorSizeB()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:137
static constexpr index_t GetVectorSizeC()
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:141
remove_cvref_t< std::tuple_element_t< 0, BsDataType > > BDataType
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:109
static constexpr index_t NPerBlock
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:128
remove_cvref_t< typename Problem::CDataType > CDataType
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:95
static constexpr index_t MPerBlock
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:127
static constexpr bool kPadK
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:150
static constexpr bool DoubleSmemBuffer
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:152
remove_cvref_t< typename Problem::AsDataTypeTuple > AsDataType
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:93
CK_TILE_DEVICE auto operator()(const AsDramBlockWindowTmp &a_dram_block_window_tmp, const AElementFunction &a_element_func, const BsDramBlockWindowTmp &b_dram_block_window_tmp, const BElementFunction &b_element_func, index_t num_loop, void *__restrict__ p_smem) const
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:713
static constexpr index_t Preshuffle
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:153
remove_cvref_t< std::tuple_element_t< 0, AsLayout > > ALayout
Definition gemm_pipeline_ag_bg_cr_comp_v6.hpp:105
Definition gemm_pipeline_ag_bg_cr_base.hpp:13
CK_TILE_DEVICE constexpr auto GetBWindows(const BDramBlockWindowTmp &b_dram_block_window_tmp, const BLdsTensorView &b_lds_block_view, const BLdsLoadTileDistr &, const array< index_t, 2 > &offset={0, 0}) const
Definition gemm_pipeline_ag_bg_cr_base.hpp:225
remove_cvref_t< std::tuple_element_t< number< 0 >{}, BsDataType > > BDataType
Definition gemm_pipeline_ag_bg_cr_base.hpp:22
CK_TILE_DEVICE auto GetABLdsTensorViews(void *p_smem) const
Definition gemm_pipeline_ag_bg_cr_base.hpp:83
static constexpr index_t NPerBlock
Definition gemm_pipeline_ag_bg_cr_base.hpp:26
CK_TILE_DEVICE void LocalPrefetch(DstBlockTile &dst_block_tile, const SrcTileWindow &lds_tile_window, bool_constant< LoadTranspose >={}) const
Definition gemm_pipeline_ag_bg_cr_base.hpp:73
static constexpr index_t MPerBlock
Definition gemm_pipeline_ag_bg_cr_base.hpp:25
CK_TILE_DEVICE void LocalPrefill(DstTileWindow &lds_tile_window, const SrcBlockTile &src_block_tile, const ElementFunction &element_func) const
Definition gemm_pipeline_ag_bg_cr_base.hpp:57
CK_TILE_DEVICE constexpr auto GetAWindows(const ADramBlockWindowTmp &a_dram_block_window_tmp, const ALdsTensorView &a_lds_block_view, const ALdsLoadTileDistr &, const array< index_t, 2 > &offset={0, 0}) const
Definition gemm_pipeline_ag_bg_cr_base.hpp:190
remove_cvref_t< std::tuple_element_t< number< 0 >{}, AsDataType > > ADataType
Definition gemm_pipeline_ag_bg_cr_base.hpp:20
static constexpr index_t KPerBlock
Definition gemm_pipeline_ag_bg_cr_base.hpp:27
Definition tile/core/numeric/integral_constant.hpp:30
Definition tile/core/numeric/numeric.hpp:81
Definition tile/core/utility/functional.hpp:43