CumSum
功能说明
函数原型
- 通过sharedTmpBuffer入参传入临时空间
1 2
template <typename T, const CumSumConfig &config = defaultCumSumConfig> __aicore__ inline void CumSum(LocalTensor<T> &dstTensor, LocalTensor<T> &lastRowTensor, const LocalTensor<T> &srcTensor, LocalTensor<uint8_t> &sharedTmpBuffer, const CumSumInfo &cumSumInfo)
- 接口框架申请临时空间
1 2
template <typename T, const CumSumConfig &config = defaultCumSumConfig> __aicore__ inline void CumSum(LocalTensor<T> &dstTensor, LocalTensor<T> &lastRowTensor, const LocalTensor<T> &srcTensor, const CumSumInfo &cumSumInfo)
参数说明
参数名 |
描述 |
||
---|---|---|---|
T |
操作数的数据类型。 |
||
config |
定义CumSum接口编译时config参数。
|
参数名 |
输入/输出 |
描述 |
||
---|---|---|---|---|
dstLocal |
输出 |
目的操作数。按first轴或last轴处理,输入元素的累加和。 类型为LocalTensor。 |
||
lastRowTensor |
输出 |
目的操作数。模板参数config中的outputLastRow参数取值为true时,输出的最后一行数据。 类型为LocalTensor,支持的TPosition为VECIN/VECCALC/VECOUT。 |
||
srcLocal |
输入 |
源操作数。 类型为LocalTensor,支持的TPosition为VECIN/VECCALC/VECOUT。 源操作数的数据类型需要与目的操作数保持一致。 |
||
cumSumInfo |
输入 |
srcTensor的shape信息。CumSumInfo类型,具体定义如下:
CumSumInfo.inner*sizeof(T)必须是32字节的整数倍 |
||
sharedTmpBuffer |
输入 |
临时缓存。 类型为LocalTensor,支持的TPosition为VECIN/VECCALC/VECOUT。 用于Cumsum内部复杂计算时存储中间变量,由开发者提供。 临时空间大小BufferSize的获取方式请参考GetCumSumMaxMinTmpSize。 |
返回值
无
支持的型号
约束说明
- 操作数地址偏移对齐要求请参见通用约束。
- 输入input只支持二维结构
- inner必须是32B的整数
调用示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 | #include "kernel_operator.h" template <typename T> class KernelCumSum { public: __aicore__ inline KernelCumSum(){} __aicore__ inline void Init( GM_ADDR srcGm, GM_ADDR dstGm, GM_ADDR lastRowGm, const AscendC::CumSumInfo& cumSumParams) { outer = cumSumParams.outter; inner = cumSumParams.inner; srcGlobal.SetGlobalBuffer(reinterpret_cast<__gm__ T *>(srcGm), outer * inner); dstGlobal.SetGlobalBuffer(reinterpret_cast<__gm__ T *>(dstGm), outer * inner); lastRowGlobal.SetGlobalBuffer(reinterpret_cast<__gm__ T *>(lastRowGm), inner); pipe.InitBuffer(inQueueX, 1, outer * inner * sizeof(T)); pipe.InitBuffer(outQueue, 1, outer * inner * sizeof(T)); pipe.InitBuffer(lastRowQueue, 1, inner * sizeof(T)); } __aicore__ inline void Process() { CopyIn(); Compute(); CopyOut(); } private: __aicore__ inline void CopyIn() { AscendC::LocalTensor<T> srcLocal = inQueueX.AllocTensor<T>(); AscendC::DataCopy(srcLocal, srcGlobal, outer * inner); inQueueX.EnQue(srcLocal); } __aicore__ inline void Compute() { AscendC::LocalTensor<T> dstLocal = outQueue.AllocTensor<T>(); AscendC::LocalTensor<T> lastRowLocal = lastRowQueue.AllocTensor<T>(); AscendC::LocalTensor<T> srcLocal = inQueueX.DeQue<T>(); static constexpr AscendC::CumSumConfig cumSumConfig{true, false, true}; const AscendC::CumSumInfo cumSumInfo{outer, inner}; AscendC::CumSum<T, cumSumConfig>(dstLocal, lastRowLocal, srcLocal, cumSumInfo); outQueue.EnQue<T>(dstLocal); lastRowQueue.EnQue<T>(lastRowLocal); inQueueX.FreeTensor(srcLocal); } __aicore__ inline void CopyOut() { AscendC::LocalTensor<T> dstLocal = outQueue.DeQue<T>(); AscendC::DataCopy(dstGlobal, dstLocal, outer * inner); outQueue.FreeTensor(dstLocal); AscendC::LocalTensor<T> lastRowLocal = lastRowQueue.DeQue<T>(); AscendC::DataCopy(lastRowGlobal, lastRowLocal, inner); lastRowQueue.FreeTensor(lastRowLocal); } private: AscendC::GlobalTensor<T> srcGlobal; AscendC::GlobalTensor<T> dstGlobal; AscendC::GlobalTensor<T> lastRowGlobal; AscendC::TPipe pipe; AscendC::TQue<AscendC::QuePosition::VECIN, 1> inQueueX; AscendC::TQue<AscendC::QuePosition::VECOUT, 1> outQueue; AscendC::TQue<AscendC::QuePosition::VECOUT, 1> lastRowQueue; uint32_t outer{1}; uint32_t inner{1}; }; template <typename T> __aicore__ inline void kernel_cumsum_operator( GM_ADDR srcGm, GM_ADDR dstGm, GM_ADDR lastRowGm, const AscendC::CumSumInfo &cumSumParams) { KernelCumSum<T> op; op.Init(srcGm, dstGm, lastRowGm, cumSumParams); op.Process(); } |