CUDA执行模型

一、CUDA执行模型概述

二、线程束执行

1. 线程束与线程块

线程束是SM中基本的执行单元。

当一个线程块的网格被启动后,网格中的线程块分布在SM中。

一旦线程块被调度到一个SM中,线程块中的线程会被进一步划分成线程束。

一个线程束由32个连续的线程组成,在一个线程束中,所有的线程按照单指令多线程方式执行。

所有线程都执行相同的指令,每个线程在私有数据上进行操作。

从逻辑角度看,线程块是线程的集合,可以被组织成一维、二维或三维布局。

从硬件角度看,线程块是一维线程束的集合。在线程块中线程被组织成一维布局,每32个连续线程组织成一个线程束。

2. 线程束分化

GPU是相对简单的设备,没有复杂的分支预测机制。

一个线程束中的所有线程在同一周期中必须执行相同的指令,如果一个线程执行一条指令,那么线程束中的所有线程都必须执行该指令。

为了获得最佳的性能,应该避免在同一个线程束中有不同的执行路径,以确保同一个线程束中所有的线程在一个应用程序中使用同一个控制路径。

相关推荐
cch89181 分钟前
PHP vs C#:语言对比与实战选型
开发语言·c#·php
KevinCyao2 分钟前
Ruby短信营销接口示例代码:Ruby开发环境下营销短信API接口的集成与Demo演示
开发语言·前端·ruby
葳_人生_蕤2 分钟前
hot100——双指针法专题
java·前端·数据库
让学习成为一种生活方式5 分钟前
取消“为 LAN 使用代理服务器”--随笔023
开发语言·php
天桥下的卖艺者6 分钟前
R语言使用TrialEmulation包快速进行数据模拟RCT研究(真实世界研究)
开发语言·r语言·模拟rct
无风听海7 分钟前
NET10之C# Primary Constructor 深度指南
开发语言·c#·.net10
Omics Pro8 分钟前
基因集(模块)活性量化:R语言+Java原生
大数据·开发语言·前端·javascript·数据库·r语言·aigc
RDCJM9 分钟前
index.php 和 php
开发语言·php
chushiyunen11 分钟前
llama-index 数据清洗示例、数据清洗等
java·大数据·llama
sycmancia11 分钟前
C++——Qt中的消息处理
开发语言·qt