DeQue
功能说明
将Tensor从队列中取出,用于后续处理。
函数原型
- 无需指定源和目的位置
1 2
template <typename T> __aicore__ inline LocalTensor<T> DeQue()
- 需要指定源和目的位置
通过TQueBind绑定VECIN和VECOUT可实现VECIN和VECOUT内存复用,如下接口用于存在Vector计算的场景下实现复用,在出队时需要指定源和目的位置;不存在Vector计算的场景下可直接调用LocalTensor<T> DeQue()出队接口。
1 2
template <TPosition srcUserPos, TPosition dstUserPos, typename T> __aicore__ inline LocalTensor<T> DeQue()
图1 将LocalTensor通过EnQue放入A1/B1的Queue中后再通过DeQue搬出
参数说明
无。
支持的型号
Atlas 训练系列产品
Atlas推理系列产品AI Core
Atlas推理系列产品Vector Core
Atlas A2训练系列产品/Atlas 800I A2推理产品
Atlas 200I/500 A2推理产品
注意事项
无
返回值
从队列中取出的LocalTensor。
调用示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | // 接口: DeQue Tensor AscendC::TPipe pipe; AscendC::TQue<AscendC::TPosition::VECOUT, 4> que; int num = 4; int len = 1024; pipe.InitBuffer(que, num, len); AscendC::LocalTensor<half> tensor1 = que.AllocTensor<half>(); que.EnQue(tensor1); AscendC::LocalTensor<half> tensor2 = que.DeQue<half>(); // 将tensor从VECOUT的Queue中搬出 // 接口: DeQue Tensor,指定特定的Src/Dst position AscendC::TPipe pipe; AscendC::TQueBind<AscendC::QuePosition::VECIN, AscendC::QuePosition::VECOUT, 1> que; int num = 4; int len = 1024; pipe.InitBuffer(que, num, len); AscendC::LocalTensor<half> tensor1 = que.AllocTensor<half>(); que.EnQue<AscendC::QuePosition::GM, AscendC::QuePosition::VECIN, half>(tensor1); // 将tensor从VECIN的Queue中搬出 AscendC::LocalTensor<half> tensor2 = que.DeQue<AscendC::QuePosition::GM, AscendC::QuePosition::VECIN, half>(); |
父主题: TQue