CreateVecIndex
Applicability
|
Product |
Supported/Unsupported |
|---|---|
|
|
√ |
|
|
√ |
|
|
√ |
|
|
√ |
|
|
x |
|
|
x |
Function Usage
Creates a vector index with a specified start value.
Prototype
- Computation of the first n data elements of a tensor
1 2
template <typename T> __aicore__ inline void CreateVecIndex(LocalTensor<T> dst, const T &firstValue, uint32_t count)
- High-dimensional tensor sharding computation
- Bitwise mask mode
1 2
template <typename T> __aicore__ inline void CreateVecIndex(LocalTensor<T> &dst, const T &firstValue, uint64_t mask[], uint8_t repeatTime, uint16_t dstBlkStride, uint8_t dstRepStride)
- Contiguous mask mode
1 2
template <typename T> __aicore__ inline void CreateVecIndex(LocalTensor<T> &dst, const T &firstValue, uint64_t mask, uint8_t repeatTime, uint16_t dstBlkStride, uint8_t dstRepStride)
- Bitwise mask mode
Parameters
|
Parameter |
Description |
|---|---|
|
T |
Operand data type. For the For the For the For the |
|
Parameter |
Input/Output |
Meaning |
|---|---|---|
|
dst |
Output |
Destination operand. The type is LocalTensor, and the supported TPosition is VECIN, VECCALC, or VECOUT. The start address of the LocalTensor must be 32-byte aligned. |
|
firstValue |
Input |
The first value of the index. The data type must be the same as that of the element in dstLocal. |
|
count |
Input |
Number of elements involved in the computation. |
|
mask/mask[] |
Input |
The mask parameter is used to control the elements involved in computation in each iteration.
|
|
repeatTime |
Input |
Number of iteration repeats. The Vector Unit reads 256 bytes of contiguous data for computation each time. To read the complete data for processing, the unit needs to read the input data in multiple repeats. repeatTime indicates the number of repeats. |
|
dstBlkStride |
Input |
Address stride of the destination operand between different data blocks in a single repeat |
|
dstRepStride |
Input |
Address stride of the destination operand for the same data block between adjacent repeats |
Returns
None
Restrictions
- For details about the operand address alignment requirements, see General Address Alignment Restrictions.
- Ensure that the value of firstValue is within the value range corresponding to the data type of the elements in dst.
Examples
This example shows only part of the code used in the computation process (Compute). To run the sample code, copy the code snippet and replace related code snippets of the Compute function in Template Samples.
- Example of high-dimensional tensor sharding computation (contiguous mask mode)
1 2 3 4 5
uint64_t mask = 128; // repeatTime = 1 // dstBlkStride = 1. Data is continuously written in a single repeat. // dstRepStride = 8, continuous data write between adjacent repeats. AscendC::CreateVecIndex(dstLocal, (T)0, mask, repeatTime, dstBlkStride, dstRepStride);
- Example of high-dimensional tensor sharding computation (bitwise mask mode)
1 2 3 4 5
uint64_t mask[2] = { UINT64_MAX, UINT64_MAX }; // repeatTime = 1 // dstBlkStride = 1. Data is continuously written in a single repeat. // dstRepStride = 8, continuous data write between adjacent repeats. AscendC::CreateVecIndex(dstLocal, (T)0, mask, repeatTime, dstBlkStride, dstRepStride);
- Example of computing the first n data elements of a tensor
1AscendC::CreateVecIndex(dstLocal, (T)0, 128);
Input data (firstValue): 0 Output data (dstLocal): [0 1 2... 127]
Template Samples
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 |
#include "kernel_operator.h" template <typename T> class CreateVecIndexTest { public: __aicore__ inline CreateVecIndexTest() {} __aicore__ inline void Init(GM_ADDR dstGm, uint64_t mask, uint8_t repeatTime, uint16_t dstBlkStride, uint8_t dstRepStride) { m_mask = mask; m_repeatTime = repeatTime; m_dstBlkStride = dstBlkStride; m_dstRepStride = dstRepStride; m_elementCount = m_dstBlkStride * m_dstRepStride * 32 * m_repeatTime / sizeof(T); m_dstGlobal.SetGlobalBuffer((__gm__ T*)dstGm); m_pipe.InitBuffer(m_queOut, 1, m_dstBlkStride * m_dstRepStride * 32 * m_repeatTime); m_pipe.InitBuffer(m_queTmp, 1, 1024); } __aicore__ inline void Process() { CopyIn(); Compute(); CopyOut(); } private: __aicore__ inline void CopyIn() { ; } __aicore__ inline void Compute() { AscendC::LocalTensor<T> dstLocal = m_queOut.AllocTensor<T>(); AscendC::LocalTensor<uint8_t> tmpLocal = m_queTmp.AllocTensor<uint8_t>(); AscendC::Duplicate(dstLocal, (T)0, m_elementCount); AscendC::PipeBarrier<PIPE_ALL>(); AscendC::CreateVecIndex(dstLocal, (T)0, m_repeatTime * 256 / sizeof(T)); m_queOut.EnQue(dstLocal); m_queTmp.FreeTensor(tmpLocal); } __aicore__ inline void CopyOut() { AscendC::LocalTensor<T> dstLocal = m_queOut.DeQue<T>(); AscendC::DataCopy(m_dstGlobal, dstLocal, m_elementCount); m_queOut.FreeTensor(dstLocal); } private: AscendC::TPipe m_pipe; uint32_t m_elementCount; uint32_t m_mask; uint32_t m_repeatTime; uint32_t m_dstBlkStride; uint32_t m_dstRepStride; AscendC::GlobalTensor<T> m_dstGlobal; AscendC::TQue<AscendC::TPosition::VECOUT, 1> m_queOut; AscendC::TQue<AscendC::TPosition::VECIN, 1> m_queTmp; }; // class CreateVecIndexTest template <typename T> __global__ __aicore__ void testCreateVecIndex(GM_ADDR dstGm, uint64_t mask, uint8_t repeatTime, uint16_t dstBlkStride, uint8_t dstRepStride) { CreateVecIndexTest<T> op; op.Init(dstGm, mask, repeatTime, dstBlkStride, dstRepStride); op.Process(); } |