num_threads
产 品 支 持 情 况
- Ascend 950PR/Ascend 950DT:支 持
- Atlas A3 训 练 系 列 产 品/Atlas A3 推 理 系 列 产 品:不 支 持
- Atlas A2 训 练 系 列 产 品/Atlas A2 推 理 系 列 产 品:不 支 持
- Atlas 200I/500 A2 推 理 产 品:不 支 持
- Atlas 推 理 系 列 产 品AI Core:不 支 持
- Atlas 推 理 系 列 产 品Vector Core:不 支 持
- Atlas 训 练 系 列 产 品:不 支 持
功 能 说 明
获 取coalesced_group组 内 线 程 总 数。
函 数 原 型
C++
unsigned long long num_threads() const
参 数 说 明
无
返 回 值 说 明
coalesced_group组 内 线 程 总 数。
约 束 说 明
无
调 用 示 例
示 例 代 码 中 偶 数id的 线 程 使 用coalesced_group进 行 协 同,奇 数 线 程 独 立 执 行 业 务,一 个Warp中 共 有16个 偶 数id的 线 程。
SIMT编 程 场 景:
C++using namespace cooperative_groups; __global__ void simt_kernel(...) { ... if (threadIdx.x % 2 == 0) { coalesced_group active = coalesced_threads(); unsigned long long thread_num = active.num_threads(); // 返 回16 } ... }SIMD与SIMT混 合 编 程 场 景:
C++using namespace cooperative_groups; __simt_vf__ inline void simt_kernel(...) { ... if (threadIdx.x % 2 == 0) { coalesced_group active = coalesced_threads(); unsigned long long thread_num = active.num_threads(); // 返 回16 } ... }