aclnnAddmm&aclnnInplaceAddmm
产品支持情况
功能说明
接口功能:计算α 乘以mat1与mat2的乘积,再与β和self的乘积求和。
计算公式:
示例:
- 对于aclnnAddmm接口,self的shape是[1, n], mat1的shape是[m, k], mat2的shape是[k, n], mat1和mat2的矩阵乘的结果shape是[m, n], self的shape能broadcast到[m, n]。
- 对于aclnnAddmm接口,self的shape是[m, 1], mat1的shape是[m, k], mat2的shape是[k, n], mat1和mat2的矩阵乘的结果shape是[m, n], self的shape能broadcast到[m, n]。
- 对于aclnnAddmm接口,self的shape是[m, n], mat1的shape是[m, k], mat2的shape是[k, n], mat1和mat2的矩阵乘的结果shape是[m, n]。
- 对于aclnnInplaceAddmm接口,直接在输入张量selfRef的内存中存储计算结果,self的shape是[m, n], mat1的shape是[m, k], mat2的shape是[k, n]。
函数原型
- aclnnAddmm和aclnnInplaceAddmm实现相同的功能,使用区别如下,请根据自身实际场景选择合适的算子。
- aclnnAddmm:需新建一个输出张量对象存储计算结果。
- aclnnInplaceAddmm:无需新建输出张量对象,直接在输入张量的内存中存储计算结果。
- 每个算子分为,必须先调用 “aclnnAddmmGetWorkspaceSize” 或者 “aclnnInplaceAddmmGetWorkspaceSize” 接口获取入参并根据计算流程计算所需workspace大小,再调用 “aclnnAddmm” 或者 “aclnnInplaceAddmm” 接口执行计算。
[object Object]
[object Object]
[object Object]
[object Object]
aclnnAddmmGetWorkspaceSize
参数说明:
[object Object]- [object Object]Atlas 训练系列产品[object Object]、[object Object]Atlas 推理系列产品[object Object]:
- 不支持BFLOAT16数据类型;
- 当输入数据类型为FLOAT32时不支持cubeMathType=0;
- cubeMathType=1,当输入数据类型为FLOAT32时,会转换为FLOAT16计算,当输入为其他数据类型时不做处理;
- 不支持cubeMathType=3。
- [object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]、[object Object]Atlas A3 训练系列产品/Atlas A3 推理系列产品[object Object]:
- cubeMathType=1,当输入数据类型为FLOAT32时,会转换为HFLOAT32计算,当输入为其他数据类型时不做处理;
- cubeMathType=2,当输入数据类型为BFLOAT16时不支持该选项;
- cubeMathType=3,当输入数据类型为FLOAT32时,会转换为HFLOAT32计算,当输入为其他数据类型时不支持该选项。
- [object Object]Atlas 训练系列产品[object Object]、[object Object]Atlas 推理系列产品[object Object]:
返回值:
第一段接口完成入参校验,出现如下场景时报错:
[object Object]
aclnnAddmm
aclnnInplaceAddmmGetWorkspaceSize
参数说明:
[object Object]- [object Object]Atlas 训练系列产品[object Object]、[object Object]Atlas 推理系列产品[object Object]:
- 不支持BFLOAT16数据类型;
- 当输入数据类型为FLOAT32时不支持cubeMathType=0;
- cubeMathType=1,当输入数据类型为FLOAT32时,会转换为FLOAT16计算,当输入为其他数据类型时不做处理;
- 不支持cubeMathType=3。
- [object Object]Atlas A2 训练系列产品/Atlas A2 推理系列产品[object Object]、[object Object]Atlas A3 训练系列产品/Atlas A3 推理系列产品[object Object]:
- cubeMathType=1,当输入数据类型为FLOAT32时,会转换为HFLOAT32计算,当输入为其他数据类型时不做处理;
- cubeMathType=2,当输入数据类型为BFLOAT16时不支持该选项;
- cubeMathType=3,当输入数据类型为FLOAT32时,会转换为HFLOAT32计算,当输入为其他数据类型时不支持该选项。
- [object Object]Atlas 训练系列产品[object Object]、[object Object]Atlas 推理系列产品[object Object]:
返回值:
第一段接口完成入参校验,出现如下场景时报错:
[object Object]
aclnnInplaceAddmm
约束说明
- 确定性说明:
- [object Object]Atlas 训练系列产品[object Object]、[object Object]Atlas 推理系列产品[object Object]:aclnnAddmm&aclnnInplaceAddmm默认非确定性实现,支持通过aclrtCtxSetSysParamOpt开启确定性。
调用示例
[object Object]