triton.language.permute

1 功能作用说明

根据dims参数重新排列张量的维度,不改变张量的数据,仅改变维度的顺序。支持任意维度的重新排列。

语法:

  • triton.language.permute(input, dims) - 函数调用形式

  • input.permute(dims) - 成员函数形式

功能:

  • 根据dims参数重新排列张量的维度

  • 不改变张量的数据,仅改变维度的顺序

  • 支持任意维度的重新排列

2 参数规格

2.1 参数说明

参数名

类型

必需

说明

input

tensor

输入张量

dims

List[int]

新的维度顺序

返回值:

  • 类型: tensor

  • 形状: 按照dims参数重新排列的维度

  • 数据类型: 与输入张量相同

  • 内存布局: 通过改变步长信息实现转置,无数据拷贝

约束条件:

  • dims必须包含输入张量的所有维度索引

2.2 DataType支持表

支持情况

int8

int16

int32

int64

uint8

uint16

uint32

uint64

float16

float32

bfloat16

float8e4

float8e5

float64

bool

Ascend A2/A3

×

×

×

×

×

×

GPU支持

2.3 Shape支持表

支持任意维度数、任意形状大小。

2.4 特殊限制说明

  • 不支持维度高于8的转置

2.5 使用方法

import triton
import triton.language as tl

@triton.jit
def permute_example():
    # 创建2x3x4的张量
    x = tl.zeros([2, 3, 4], dtype=tl.float32)

    # 转置维度,变成4x2x3
    y = tl.permute(x, [2, 0, 1])

    return y

## 调用示例
result = permute_example()
print(result.shape)  # 输出: (4, 2, 3)