CUDA执行模型

一、CUDA执行模型概述

二、线程束执行

1. 线程束与线程块

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

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

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

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

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

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

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

2. 线程束分化

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

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

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

相关推荐
穿条秋裤到处跑8几秒前
java2AI系列:SpringAI 通过 Function Calling 接入外部系统
java·人工智能
HoneyMoose1 分钟前
Npmp 安装时候提示警告: error (ERR_INVALID_THIS)
开发语言
亚空间仓鼠2 分钟前
Ansible之Playbook(四):循环与判断
java·服务器·ansible
gskyi2 分钟前
时间格式化神器:智能显示相对时间
开发语言·javascript·ecmascript
古城小栈7 分钟前
Rust在当下AI领域的用武之地:从底层加速到上层应用全解析
开发语言·人工智能·rust
lsx2024068 分钟前
SQLite Where 子句详解
开发语言
希望永不加班10 分钟前
SpringBoot 依赖管理:BOM 与版本控制
java·spring boot·后端·spring
专注VB编程开发20年11 分钟前
VBA/VB6 ADO数据库查询jet+只读更快
开发语言·数据库·ado·vb
jiayong2311 分钟前
第 11 课:把筛选条件同步到 URL
开发语言·前端·javascript
曹牧12 分钟前
MantisBT
开发语言