开发者
资源
[object Object]

数据排布格式(Data Layout Format)是深度学习中对多维Tensor在内存中存储方式的描述。

常见的数据格式包括ND、NHWC和NCHW等,为Tensor的每个轴赋予了特定的业务语义。

除了上述NHWC和NCHW格式外,还存在一些特殊的私有数据格式,如FRACTAL_NZ(也简称NZ)、NC1HWC0、FRACTAL_Z、NDC1HWC0、FRACTAL_Z_3D等。这些格式的引入是为了满足AI Core中Cube计算单元的高性能计算需求,通过优化内存布局,这些格式能够提升计算效率。在使用矩阵乘、卷积API开发相关算子的过程中,您可以看到这些格式的具体应用。

[object Object]
  • ND、NHWC和NCHW

    数据排布格式最初用于表示图像在内存中的存储方式,其中常见的包括ND、NHWC和NCHW。在一般情况下,所有的Tensor都是N维的(ND),而NHWC和NCHW则是为四维Tensor中的每个轴赋予了特定的业务语义,例如高度(Height)、宽度(Width)和通道数(Channels)。

    NHWC和NCHW的主要区别在于通道(Channel)维度的位置:

    • NHWC格式中,通道维度位于最后一个位置。
    • NCHW格式中,通道维度位于高度和宽度之前。

    具体解释每个轴的含义:

    • N:Batch数量,表示图像的数目。
    • H:Height,图像的高度,即垂直方向的像素个数。
    • W:Width,图像的宽度,即水平方向的像素个数。
    • C:Channels,图像的通道数,例如彩色RGB图像的Channels为3。

    所示,以一张格式为RGB的图片为例,NCHW中,C排列在外层,实际存储的是“RRRRRRGGGGGGBBBBBB”,即同一通道的所有像素值顺序存储在一起;而NHWC中C排列在最内层,实际存储的则是“RGBRGBRGBRGBRGBRGB”,即多个通道的同一位置的像素值顺序存储在一起。

    图 1 NCHW和NHWC存储示例[object Object][object Object]

    尽管存储的数据相同,但不同的存储顺序会导致数据的访问特性不一致,因此即便进行同样的运算,相应的计算性能也会不同。

  • NDHWC和NCDHW

    NDHWC和NCDHW是五维Tensor,较NHWC和NCHW多了一个D的维度,D代表特征深度(Depth),表示数据在深度方向上的扩展,如视频的时间步或医学图像的深度层,因此该类格式便于在时间维度上进行卷积操作。以NDHWC为例,其数据格式如下图所示:

[object Object]

使用Mmad基础API进行矩阵乘计算时,对矩阵输入输出的数据排布格式有一定的要求,如下图所示,要求A矩阵(位于L0A Buffer)为FRACTAL_ZZ,B矩阵(位于L0B Buffer)为FRACTAL_ZN,C矩阵(位于L0C Buffer)为FRACTAL_NZ。这些格式将矩阵划分成了一些分形(Fractal Matrix),适配Cube计算单元每次读取(16, 16)× (16, 16) 的数据进行计算的硬件特点(以half数据类型为例),从而提高矩阵计算的效率。分形的大小和数据类型有关,也和所在的存储位置有关,具体可参见下文的详细介绍。

  • FRACTAL_NZ/NZ

[object Object][object Object]

[object Object]
  • FRACTAL_ZZ/ZZ

    FRACTAL_ZZ格式,简称ZZ格式,是对一个Tensor最低两维(一个Tensor的所有维度,右侧为低维,左侧为高维)进行填充(pad)、拆分(reshape)和转置(transpose)操作后得到的格式。具体转换过程如下:

    (M, K)大小的矩阵被分为M1 * K1个分形,按照row major排布,形状如Z字形;每个分形内部有M0 * K0个元素,按照row major排布,形状如Z字形,所以这种数据格式称为ZZ格式。其中,(M0, K0)表示一个分形的大小,分形Shape为16 x (32B / sizeof(Datatype)),大小为512字节。

    通过公式表达转换过程如下:

    [object Object]

    对于不同的数据类型,M0和K0的大小不同:

    • 位宽为4的数据类型:M0=16,K0=64。
    • 位宽为8的数据类型:M0=16,K0=32。
    • 位宽为16的数据类型:M0=16,K0=16。
    • 位宽为32的数据类型,M0=16,K0=8。
  • FRACTAL_ZN/ZN

    FRACTAL_ZN格式,简称ZN格式,是对一个Tensor最低两维(一个Tensor的所有维度,右侧为低维,左侧为高维)进行填充(pad)、拆分(reshape)和转置(transpose)操作后得到的格式。具体转换过程如下:

    (K, N)大小的矩阵被分为K1 * N1个分形,按照row major排布,形状如Z字形;每个分形内部有K0 * N0个元素,按照column major排布,形状如N字形,所以这种数据格式称为ZN格式。其中,(K0, N0)表示一个分形的大小,分形shape为 (32B / sizeof(Datatype)) x 16,大小为512字节。

    通过公式表达转换过程如下:

    [object Object]

    对于不同的数据类型,K0和N0的大小不同:

    • 位宽为4的数据类型:K0=64,N0=16;
    • 位宽为8的数据类型:K0=32,N0=16;
    • 位宽为16的数据类型:K0=16,N0=16;
    • 位宽为32的数据类型:K0=8,N0=16。
[object Object]
  • NC1HWC0

    AI处理器中,为了提高通用矩阵乘法(GEMM)运算数据块的访问效率,所有张量数据统一采用NC1HWC0的五维数据格式。其中C0与微架构强相关,等于AI Core中矩阵计算单元的大小。

    C1=(C+C0-1)/C0。如果结果不整除,向下取整。

    NHWC/NCHW -> NC1HWC0的转换过程为:将数据在C维度进行分割,变成C1份NHWC0/NC0HW,再将C1份NHWC0/NC0HW在内存中连续排列成NC1HWC0,其格式转换示意图如下图所示。

    • NHWC -> NC1HWC0的转换公式如下:

      [object Object]
    • NCHW -> NC1HWC0的转换公式如下:

      [object Object]
  • FRACTAL_Z

    FRACTAL_Z是用于定义卷积权重的数据格式,由FT Matrix(FT:Filter,卷积核)变换得到。FRACTAL_Z是送往Cube的最终数据格式,采用“C1HW,N1,N0,C0”的4维数据排布。

    数据有两层Tiling,如下图所示:

    第一层与Cube的Size相关,数据按照列的方向连续(小n);第二层与矩阵的Size相关,数据按照行的方向连续(大Z)。

    例如:HWCN = (2, 2, 32, 32),将其变成FRACTAL_Z(C1HW, N1, N0, C0) = (8, 2, 16, 16)。

    HWCN变换FRACTAL_Z的过程为:

    [object Object]

    NCHW变换FRACTAL_Z的过程为:

    [object Object]
  • NDC1HWC0

    为了提高矩阵乘法运算数据块的访问效率,将NDHWC转换为NDC1HWC0格式。其中C0与微架构强相关,等于AI Core中矩阵计算单元的大小,对于float16_t类型为16,对于int8_t类型则为32,这部分数据需要连续存储。

    C1=(C+C0-1)/C0。如果结果不整除,向下取整。

    NDHWC -> NDC1HWC0的转换过程为:将数据在C维度进行分割,变成C1份NDHWC0,再将C1份NDHWC0在内存中连续排列成NDC1HWC0,其格式转换示意图如下图所示。

  • FRACTAL_Z_3D

    FRACTAL_Z_3D是3D卷积权重格式,例如Conv3D算子都会涉及到用这种格式来表达3D卷积的权重。

    NDHWC –> FRACTAL_Z_3D的变换过程通过公式表达如下:

    [object Object]

    对于不同的数据类型,C0和N0的大小不同:

    • 位宽为4的数据类型:C0=64,N0=16;
    • 位宽为8的数据类型:C0=32,N0=16;
    • 位宽为16的数据类型:C0=16,N0=16;
    • 位宽为32的数据类型:C0=8,N0=16。

    输入一个NDHWC格式的Tensor,Shape大小为(48, 2, 2, 2, 32):

    转换后,得到FRACTAL_Z_3D格式如下所示:

[object Object]
  • **BSH/SBH:**B:Batch,批处理的大小; S:sequence length,序列长度;H = N * D,其中,N为head的数量,D为head的大小,此格式通常用于Matmul矩阵乘。数据排布格式如下图所示:

  • BMNK:通用数据格式;B:Batch,批处理的大小;M、N、K为矩阵乘[M, K]*[K, N]的矩阵维度;其数据排布格式如下:

  • BSNGD:为原始BSH shape做reshape后的shape,S和D为单Batch的矩阵乘的M轴(或N轴)和K轴,一个SD为一个batch的计算数据,此格式通常用于Matmul矩阵乘,数据排布格式如下图所示:

  • SBNGD:为原始SBH shape做reshape后的shape,S和D为单Batch的矩阵乘的M轴(或N轴)和K轴,一个SD为一个Batch的计算数据,此格式通常用于Matmul矩阵乘,数据排布格式如下图所示:

  • BNGS1S2:一般为前两种数据排布进行矩阵乘的输出,S1S2数据连续存放,一个S1S2为一个Batch的计算数据,此格式通常用于Matmul矩阵乘,数据排布格式如下图所示:

  • ND_ALIGN:ND_ALIGN是ND数据格式

[object Object][object Object]的一种变换数据格式。输出矩阵乘的结果矩阵C时,用于配置C矩阵按照N方向32字节对齐的规则进行输出。

[object Object]
  • VECTOR:VECTOR是

[object Object][object Object](矩阵向量乘,General Matrix-Vector Multiply)场景使用的一种数据格式,配置矩阵为VECTOR数据排布格式即代表输入数据是一个向量。

[object Object]
[object Object]

ND数据排布格式也称为ROW_MAJOR(行优先),相应的有COLUMN_MAJOR(列优先)。这两种数据排布格式的区别是数组或矩阵中哪个方向上的连续元素在内存连续。

  • ROW_MAJOR:行方向的连续元素在内存上连续。
  • COLUMN_MAJOR:列方向的连续元素在内存上连续。

两种数据排布格式的示意图如下所示。