aclnnMatmulAlltoAll
产品支持情况
功能说明
- 接口功能:完成Matmul计算、Permute(保证通信后地址连续)和AlltoAll通信的融合,先计算后通信。
- 计算公式:假设x1的shape为(BS, H1),x2的shape为(H1, H2),rankSize为NPU卡数。
函数原型
每个算子分为,必须先调用 “aclnnMatmulAlltoAllGetWorkspaceSize”接口获取计算所需workspace大小以及包含了算子计算流程的执行器,再调用“aclnnMatmulAlltoAll”接口执行计算。
[object Object]
[object Object]
aclnnMatmulAlltoAllGetWorkspaceSize
aclnnMatmulAlltoAll
约束说明
- 默认支持确定性计算。
- NPU卡数(rankSize),根据设备型号有不同限制:
- [object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]:支持2、4、8卡。
- 参数说明中shape使用的变量H2必须整除NPU卡数。
- H1范围仅支持[1, 65535]。
- BS*rankSize和H2的值不得超过2147483647(INT32_MAX)。
- 空tensor的支持度根据不同设备型号有不同的限制:
- [object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]:不支持任何空tensor。
- x1、x2计算输入的数据类型要和output计算输出的数据类型一致,传入的x1、x2与output均不为空指针。
- biasOptional的数据类型根据不同设备型号有不同的限制:
- [object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]:output计算输出的数据类型为FLOAT16时,biasOptional计算输入的数据类型支持FLOAT16;output计算输出的数据类型为BFLOAT16时,biasOptional计算输入的数据类型支持FLOAT32。
- 通算融合算子不支持并发调用,不同的通算融合算子也不支持并发调用。
- 不支持跨超节点通信,只支持超节点内。
调用示例
示例代码如下,仅供参考,具体编译和执行过程请参考编译与运行样例。
说明:本示例代码调用了部分HCCL集合通信库接口:HcclGetCommName、HcclCommInitAll、HcclCommDestroy,请参考。
[object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]:
[object Object]