CANN 组织链接 : https://atomgit.com/cann
GE 仓库链接 : https://gitcode.com/cann/ge
1. 算子版本化在 GE 中的管理
随着模型框架(如 TensorFlow/PyTorch)的演进,它们对现有算子的定义可能会改变(例如,增加新的维度参数或更改默认的 Axis 定义)。GE 必须能够处理这种版本差异。
1.1 算子签名的细化与版本标签
GE 不仅匹配算子名称,更匹配其签名 (Signature)。
- 属性版本:每个 ops-nn 算子或自定义算子在 MetaDef 中定义了一组版本号。当 GE 解析来自框架的图时,它将框架传入的属性与已注册的算子版本进行比对。如果框架使用了一个旧版本的 MatMul 属性集,GE 会映射到对应的旧版 ops-nn 实现(即使新版已发布)。
- 图重写规则的版本化:融合规则和布局转换规则也是版本化的。例如,早期版本的 Conv2D 融合规则可能不包含对 BN 的特殊处理,而新版本则会。GE 根据编译时的配置,选择应用特定版本的优化规则集。
2. 兼容性转换层(Rewriter)的深度作用
GE 中专门负责图转换的模块(Rewriter)是确保兼容性的执行者。
2.1 模式匹配与规则应用
Rewriter 模块通过一系列的模式匹配规则来识别需要优化的子图结构。
- 操作符替换:当 GE 识别出某个操作序列(例如,两个依赖于旧版 Padding 语义的 Conv2D)时,Rewriter 会将其替换为更优化的等价形式,如一个支持新 Padding 语义的 ops-nn 算子版本,或一个 Ascend C 实现的融合算子。
- 数据类型和形状规范化:Rewriter 在图的早期阶段,会强制将图中的所有张量转换为 GE 内部和 ops-nn 期望的规范格式(如 NC1HWC0),这消除了上层框架格式差异带来的兼容性问题。
2.2 算子降级与回退处理
当 GE 无法找到硬件加速的最佳实现时,兼容性管理机制启动:
- CPU/通用核回退 :如果图中的某个操作在当前 NPU 驱动和 ops-nn 库中没有可用的高效实现,GE 会将该节点标记为回退 (Fallback),将其映射到一个通用算子(可能是 CPU 上的实现,或一个基于通用 Vector Unit 的慢速 NPU 实现)。这种机制保证了模型的完整执行能力,即使面对不支持的算子组合。
3. 总结
GE 不仅是一个调度器,更是一个智能的、版本感知的图优化和兼容性管理引擎。通过对算子签名的严格匹配和规则版本化的图重写策略,GE 确保了上层框架的不断演进不会轻易破坏底层 ops-nn 算子库的优化成果,保证了模型的稳定部署和前向兼容性。
CANN 组织链接 : https://atomgit.com/cann
GE 仓库链接 : https://gitcode.com/cann/ge