SplitOperation

功能

将输入张量沿指定维度切分成多个张量。

算子上下文

图1 SplitOperation

算子功能实现

定义

struct SplitParam {
    int32_t splitDim = 0;
    int32_t splitNum = 2;
};

参数列表

成员名称

类型

默认值

描述

splitDim

int32_t

0

指定切分的维度索引。

splitDim须位于输入张量x的维度范围内,即如果x的维度为xDim,则splitDim的取值范围为[-xDim, xDim - 1]。 当splitDim为负数时,其含义是从最高维度开始访问,如splitDim = -1,x维度数为dimNum,则拆分维度为dimNum - 1。

splitNum

int32_t

2

等分次数,当前支持2或3。

输入张量x的维度须能够被splitNum整除,且当splitNum = 3时输入x要求是float16或者bf16数据类型。

splitNum=2时输入输出

参数

维度

数据类型

格式

描述

x

[dim_0, ..., dim_splitDim,...,dim_n]

float16/int64/bf16

ND

输入,最高支持8维。

output1

  • [dim_0, …, dim_splitDim_1, ..., dim_n]
  • 当splitSizes为空时,dim_splitDim_1=dim_splitDim/2;
  • 当splitSizes不为空时,dim_splitDim_2=splitSizes[0]。

float16/int64/bf16

ND

输出,切分后的tensor。数据类型与x一致。

output2

  • [dim_0, …, dim_splitDim_2, ..., dim_n]
  • 当splitSizes为空时,dim_splitDim_2=dim_splitDim/2;
  • 当splitSizes不为空时,dim_splitDim_2=splitSizes[1]。

float16/int64/bf16

ND

输出,切分后的tensor。数据类型与x一致。

splitNum=3时输入输出

参数

维度

数据类型

格式

描述

x

[dim_0, ..., dim_splitDim,...,dim_n]

float16/bf16

ND

输入,最高支持8维。

output1

  • [dim_0, …, dim_splitDim_1, ..., dim_n]
  • 当splitSizes为空时,dim_splitDim_1=dim_splitDim/2;
  • 当splitSizes不为空时,dim_splitDim_1=splitSizes[0]。

float16/bf16

ND

输出,切分后的tensor。数据类型与x一致。

output2

  • [dim_0, …, dim_splitDim_2, ..., dim_n]
  • 当splitSizes为空时,dim_splitDim_2=dim_splitDim/3;
  • 当splitSizes不为空时,dim_splitDim_2=splitSizes[1]。

float16/bf16

ND

输出,切分后的tensor。数据类型与x一致。

output3

  • [dim_0, …, dim_splitDim_3, ..., dim_n]
  • 当splitSizes为空时,dim_splitDim_3=dim_splitDim/3;
  • 当splitSizes不为空时,dim_splitDim_3=splitSizes[2]。

float16/bf16

ND

输出,切分后的tensor。数据类型与x一致。

规格约束

接口调用示例

输入:

splitDim = 0
splitNum = 3
x = [3, 3, 3, 3, 3, 3, 3, 3, 3]

输出:

z = [3, 3, 3]
z1 = [3, 3, 3]
z2 = [3, 3, 3]