昇腾社区首页
中文
注册
开发者
下载

aclnnAddRmsNormDynamicQuantV2

产品支持情况

[object Object]undefined

功能说明

  • 接口功能:RmsNorm算子是大模型常用的归一化操作,相比LayerNorm算子,其去掉了减去均值的部分。DynamicQuant算子则是为输入张量进行对称动态量化的算子。AddRmsNormDynamicQuant算子将RmsNorm前的Add算子和RmsNorm归一化输出给到的1个或2个DynamicQuant算子融合起来,减少搬入搬出操作。aclnnAddRmsNormDynamicQuantV2相较于aclnnAddRmsNormDynamicQuant在RmsNorm计算过程中增加了偏置项betaOptional参数,即计算公式中的beta,以及新增输出配置项outputMaskOptional参数,用于配置是否输出对应位置的量化结果 。

  • 计算公式:

    x=x1+x2x=x_{1}+x_{2} y=RmsNorm(x)=xRms(x)gamma+beta, where Rms(x)=1ni=1nxi2+epsilony = \operatorname{RmsNorm}(x)=\frac{x}{\operatorname{Rms}(\mathbf{x})}\cdot gamma+beta, \quad \text { where } \operatorname{Rms}(\mathbf{x})=\sqrt{\frac{1}{n} \sum_{i=1}^n x_i^2+epsilon} input1={ysmoothScale1Optional  smoothScale1Optionaly! smoothScale1Optionalinput1 =\begin{cases} y\cdot smoothScale1Optional & \ \ smoothScale1Optional \\ y & !\ smoothScale1Optional \end{cases} input2={ysmoothScale2Optional  smoothScale2Optionaly! smoothScale2Optionalinput2 =\begin{cases} y\cdot smoothScale2Optional & \ \ smoothScale2Optional \\ y & !\ smoothScale2Optional \end{cases} scale1Out={row_max(abs(input1))/127outputMask[0]=True  !outputMask无效输出outputMask[0]=Falsescale1Out=\begin{cases} row\_max(abs(input1))/127 & outputMask[0]=True\ ||\ !outputMask \\ 无效输出 & outputMask[0]=False \end{cases} y1Out={round(input1/scale1Out)outputMask[0]=True  !outputMask无效输出outputMask[0]=Falsey1Out=\begin{cases} round(input1/scale1Out) & outputMask[0]=True\ ||\ !outputMask \\ 无效输出 & outputMask[0]=False \end{cases} scale2Out={row_max(abs(input2))/127outputMask[1]=True  (!outputMask & smoothScale1Optional & smoothScale2Optional)无效输出outputMask[1]=False  (!outputMask & smoothScale1Optional & !smoothScale2Optional)scale2Out=\begin{cases} row\_max(abs(input2))/127 & outputMask[1]=True\ ||\ (!outputMask\ \&\ smoothScale1Optional\ \&\ smoothScale2Optional) \\ 无效输出 & outputMask[1]=False\ ||\ (!outputMask\ \&\ smoothScale1Optional\ \&\ !smoothScale2Optional) \end{cases} y2Out={round(input2/scale2Out)outputMask[1]=True  (!outputMask & smoothScale1Optional & smoothScale2Optional)无效输出outputMask[1]=False  (!outputMask & smoothScale1Optional & !smoothScale2Optional)y2Out=\begin{cases} round(input2/scale2Out) & outputMask[1]=True\ ||\ (!outputMask\ \&\ smoothScale1Optional\ \&\ smoothScale2Optional)\\ 无效输出 & outputMask[1]=False\ ||\ (!outputMask\ \&\ smoothScale1Optional\ \&\ !smoothScale2Optional) \end{cases}

    公式中的row_max代表每行求最大值。

函数原型

每个算子分为,必须先调用[object Object]接口获取入参并根据计算流程所需workspace大小,再调用`aclnnAddRmsNormDynamicQuantV2接口执行计算。

[object Object]
[object Object]

aclnnAddRmsNormDynamicQuantV2GetWorkspaceSize

  • 参数说明:

    [object Object]
  • 返回值:

    aclnnStatus:返回状态码,具体参见

    第一段接口完成入参校验,出现以下场景时报错:

    [object Object]

aclnnAddRmsNormDynamicQuantV2

  • 参数说明:

    [object Object]
  • 返回值:

    aclnnStatus:返回状态码。(具体参见

约束说明

  • 数据格式说明:所有输入输出tensor的数据格式推荐使用ND格式,其他数据格式会由框架默认转换成ND格式进行处理。

  • 当outputMaskOptional不为空时,参数smoothScale1Optional有值时,则outputMaskOptional[0]必须为True。参数smoothScale2Optional有值时,则outputMaskOptional[1]必须为True。

  • 当outputMaskOptional不为空时,outputMaskOptional[0]与outputMaskOptional[1]不能同时为False。

  • 当outputMaskOptional为空时,参数smoothScale2Optional有值时,参数smoothScale1Optional也必须有值。

  • 各产品型号支持数据类型说明:

    [object Object]undefined
  • 确定性计算:

    • aclnnAddRmsNormDynamicQuantV2默认确定性实现。

调用示例

示例代码如下,仅供参考,具体编译和执行过程请参考

[object Object]