news 2026/5/11 7:52:31

CANN/ops-nn THNN融合LSTM单元梯度

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CANN/ops-nn THNN融合LSTM单元梯度

ThnnFusedLstmCellGrad

【免费下载链接】ops-nn本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-nn

产品支持情况

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

功能说明

  • 算子功能:LSTMCell中四个门中matmul后剩余计算的反向传播,计算正向输出四个门激活前的值gates、输入cx、偏置b的梯度。

  • 计算公式:

变量定义

  • 输入梯度:$\delta h_t$ (gradHy), $\delta c_t$ (gradC)
  • 前向缓存:$i,f,g,o$ (各门激活值storage),$c_{t-1}$ (cx),$c_t$ (cy)
  • 输出梯度:$\delta a_i,\delta a_f,\delta a_g,\delta a_o$ (存入gradInGatesOut),$\delta c_{t-1}$ (gradCPrevOut)

第一阶段:中间梯度与状态回传

首先计算隐藏状态对细胞状态的贡献,并汇总得到当前时刻细胞的总梯度 $\text{grad_}c_{total}$:

$$ \begin{aligned} gcx &= \tanh(c_t) \ \text{grad_}c_{total} &= \delta h_t \cdot o \cdot (1 - gcx^2) + \delta c_t \ \delta c_{t-1} &= \text{grad_}c_{total} \cdot f \end{aligned} $$

第二阶段:门控分量梯度 (Pre-activation)

根据代码逻辑,各门控在进入激活函数前的梯度 $\delta a$ 计算如下:

$$ \begin{aligned} \delta a_o &= (\delta h_t \cdot gcx) \cdot o \cdot (1 - o) \ \delta a_i &= (\text{grad_}c_{total} \cdot g) \cdot i \cdot (1 - i) \ \delta a_f &= (\text{grad_}c_{total} \cdot c_{t-1}) \cdot f \cdot (1 - f) \ \delta a_g &= (\text{grad_}c_{total} \cdot i) \cdot (1 - g^2) \end{aligned} $$

第三阶段:参数梯度 (db)

**1. 偏置梯度 (db):**对 Batch 维度($N$)进行求和:

$$ \delta b = \sum_{n=1}^{N} \begin{bmatrix} \delta a_i \ \delta a_f \ \delta a_g \ \delta a_o \end{bmatrix}_n $$

  • 参数说明:
    参数名输入/输出/属性描述数据类型数据格式
    dhy输入
    • 表示LSTMCell正向输出隐藏状态的梯度。
    • shape为[batch,hidden_size]。
    FLOAT、FLOAT16ND
    dc输入
    • 表示LSTMCell正向输出细胞状态的梯度。
    • shape为[batch,hidden_size]。
    FLOAT、FLOAT16ND
    cx输入
    • 表示LSTMCell正向输入细胞状态。
    • shape为[batch,hidden_size]。
    FLOAT、FLOAT16ND
    cy输入
    • 表示LSTMCell正向输出细胞状态。
    • shape为[batch,hidden_size]。
    FLOAT、FLOAT16ND
    storage输入
    • 表示LSTMCell正向输出四个门的激活值。
    • shape为[batch, 4 * hidden_size]。
    FLOAT、FLOAT16ND
    dgates输出
    • 表示LSTMCell正向中四个门预激活值的梯度。
    • shape为[batch, 4 * hidden_size]。
    FLOAT、FLOAT16ND
    dc_prev输入
    • 表示LSTMCell正向中输入细胞状态的梯度。
    • shape为[batch,hidden_size]。
    FLOAT、FLOAT16ND
    db输入
    • 表示LSTMCell正向中输入偏置的梯度。
    • shape为[4 * hidden_size]。
    FLOAT、FLOAT16ND
    has_bias属性是否需要计算bias梯度。STRING-

约束说明

调用说明

调用方式样例代码说明
aclnn接口test_aclnn_thnn_fused_lstm_cell_grad.cpp通过aclnnThnnFusedLstmCellBackward接口方式调用ThnnFusedLstmCellGrad算子。

【免费下载链接】ops-nn本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-nn

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 7:51:37

PacketStreamer传感器工作原理:深入解析BPF过滤机制

PacketStreamer传感器工作原理:深入解析BPF过滤机制 【免费下载链接】PacketStreamer :star: :star: Distributed tcpdump for cloud native environments :star: :star: 项目地址: https://gitcode.com/gh_mirrors/pa/PacketStreamer PacketStreamer是一款专…

作者头像 李华
网站建设 2026/5/11 7:50:56

如何在Dev-C++中配置TDM-GCC

好的,在 Dev-C 中配置 TDM-GCC 可以按照以下步骤操作:下载并安装 TDM-GCC访问 TDM-GCC 的官方网站:https://jmeubank.github.io/tdm-gcc/下载适合您系统(通常是 64 位 Windows)的最新安装程序。运行安装程序。安装路径…

作者头像 李华
网站建设 2026/5/11 7:50:16

CANN/asc-devkit:asc_arange矢量索引生成API

asc_arange 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。 项目地址: https://gitcode.com…

作者头像 李华
网站建设 2026/5/11 7:50:15

CherryPy社区与生态:如何参与贡献并获得支持的完整指南

CherryPy社区与生态:如何参与贡献并获得支持的完整指南 【免费下载链接】cherrypy CherryPy is a pythonic, object-oriented HTTP framework. https://cherrypy.dev 项目地址: https://gitcode.com/gh_mirrors/ch/cherrypy CherryPy作为一个Pythonic、面向对…

作者头像 李华
网站建设 2026/5/11 7:45:35

CANN/ops-nn自适应层归一化算子

AdaLayerNorm 【免费下载链接】ops-nn 本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-nn 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DTAtlas A3 训练系列产品/Atlas A3 推理系列产品√…

作者头像 李华
网站建设 2026/5/11 7:45:10

深度解析原神帧率解锁技术:5大核心特性与源码架构实战指南

深度解析原神帧率解锁技术:5大核心特性与源码架构实战指南 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 原神帧率解锁项目(genshin-fps-unlock)是一…

作者头像 李华