Triu

产品支持情况

产品 是否支持
Ascend 950PR/Ascend 950DT
Atlas A3 训练系列产品/Atlas A3 推理系列产品
Atlas A2 训练系列产品/Atlas A2 推理系列产品
Atlas 200I/500 A2 推理产品 ×
Atlas 推理系列产品
Atlas 训练系列产品

功能说明

  • 算子功能:将输入的self张量的最后二维(按shape从左向右数)沿对角线的左下部分置零。参数diagonal可正可负,默认为零,正数表示主对角线向右上方向移动,负数表示主对角线向左下方向移动。

  • 计算公式:下面用i表示遍历倒数第二维元素的序号(i是行索引),用j表示遍历最后一维元素的序号(j是列索引),用d表示diagonal,在(i, j)对应的二维坐标图中,i+d==j表示在对角线上。

    对角线及其右上方,即i+d<=j,保留原值:outi,j=selfi,j而位于对角线左下方的情况,即i+d>j,置零(不含对角线):outi,j=0对角线及其右上方,即i+d<=j,保留原值: out_{i, j} = self_{i, j}\\ 而位于对角线左下方的情况,即i+d>j,置零(不含对角线):out_{i, j} = 0

  • 示例:

    self=[[963][123][341]]self = \begin{bmatrix} [9&6&3] \\ [1&2&3] \\ [3&4&1] \end{bmatrix}, triu(self, diagonal=0)的结果为: [[963][023][001]]\begin{bmatrix} [9&6&3] \\ [0&2&3] \\ [0&0&1] \end{bmatrix}; 调整diagonal的值,triu(self, diagonal=1)结果为: [[063][003][000]]\begin{bmatrix} [0&6&3] \\ [0&0&3] \\ [0&0&0] \end{bmatrix}; 调整diagonal为-1,triu(self, diagonal=-1)结果为: [[963][123][041]]\begin{bmatrix} [9&6&3] \\ [1&2&3] \\ [0&4&1] \end{bmatrix}

参数说明

参数名 输入/输出/属性 描述 数据类型 数据格式
self 输入 待进行triu计算的入参,公式中的self。 FLOAT、FLOAT16、DOUBLE、BFLOAT16、INT8、INT16、INT32、INT64、UINT8、UINT16、UINT32、UINT64、BOOL、COMPLEX32、COMPLEX64 ND
diagonal 输入 待进行triu计算的入参,公式中的diagonal。 INT64 ND
out 输出 待进行triu计算的出参,公式中的out_i。 FLOAT、FLOAT16、DOUBLE、BFLOAT16、INT8、INT16、INT32、INT64、UINT8、BOOL ND
  • Atlas 推理系列产品、Atlas 训练系列产品:数据类型支持UINT64、INT64、UINT32、 INT32、UINT16、INT16、UINT8、 INT8、FLOAT16、FLOAT32、DOUBLE、BOOL。
  • Atlas A2 训练系列产品/Atlas A2 推理系列产品、Atlas A3 训练系列产品/Atlas A3 推理系列产品:数据类型支持UINT64、INT64、UINT32、 INT32、UINT16、INT16、UINT8、 INT8、FLOAT16、FLOAT32、DOUBLE、BOOL、BFLOAT16。
  • Ascend 950PR/Ascend 950DT:数据类型支持UINT64、INT64、UINT32、 INT32、UINT16、INT16、UINT8、 INT8、FLOAT16、FLOAT32、DOUBLE、BOOL、BFLOAT16、COMPLEX32、COMPLEX64。

约束说明

调用说明

调用方式 调用样例 说明
aclnn调用 test_aclnn_triu 通过aclnnTriu接口方式调用Triu算子。