获得多核切分后, 使用的BlockDim。
1 | int32_t GetCoreNum(int32_t &dim, int32_t &mDim, int32_t &nDim) |
1 | int32_t GetCoreNum(int32_t &dim, int32_t &mDim, int32_t &nDim, int32_t &batchM, int32_t &batchN) |
参数名 |
输入/输出 |
描述 |
---|---|---|
dim |
输出 |
获取计算时所需要的核数, dim = mDim * nDim |
mDim |
输出 |
获取计算时M方向所需要的核数 |
nDim |
输出 |
获取计算时N方向所需要的核数 |
batchM |
输出 |
获取计算时batch M方向所需要的核数 |
batchN |
输出 |
获取计算时batch N方向所需要的核数 |
-1表示获取失败; 0表示获取成功。
使用创建的Tiling对象调用该接口,且需在完成Tiling计算(GetTiling)后调用。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | auto ascendcPlatform = platform_ascendc::PlatformAscendC(context->GetPlatformInfo()); matmul_tiling::MultiCoreMatmulTiling tiling(ascendcPlatform); tiling.SetDim(1); tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); tiling.SetBType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); tiling.SetCType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT); tiling.SetBiasType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT); tiling.SetShape(1024, 1024, 1024); tiling.SetSingleShape(1024, 1024, 1024); tiling.SetOrgShape(1024, 1024, 1024); tiling.SetBias(true); tiling.SetBufferSpace(-1, -1, -1); optiling::TCubeTiling tilingData; int ret = tiling.GetTiling(tilingData); // 获得多核切分后, 使用的BlockDim int32_t dim, mDim, nDim; int ret1 = tiling.GetCoreNum(dim, mDim, nDim); |