CUDA执行模型

一、CUDA执行模型概述

二、线程束执行

1. 线程束与线程块

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

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

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

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

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

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

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

2. 线程束分化

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

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

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

相关推荐
武子康3 分钟前
Java-18 深入浅出 MyBatis源码中 9 大设计模式全景解析:从 SqlSessionFactory 到 PropertyTokenizer(2026
java·后端
Demon1_Coder6 分钟前
Day3-微服务-Sentinel-具体使用
java·微服务·sentinel
小科先生6 分钟前
配置java环境变量
java·开发语言
大山是只猫7 分钟前
struts 从struts 2版本 升级6.8.0 版本
java·struts2·struts6
meilindehuzi_a8 分钟前
撕开 JS 的 Class 面具:从构造函数的 new 降生到顶层原型链的终极通关
开发语言·javascript·ecmascript
天天进步201512 分钟前
Python全栈项目--智能远程医疗系统
开发语言·python
牧瀬クリスだ14 分钟前
深入解析wait与notify及多线程实战案例
java
AI人工智能+电脑小能手16 分钟前
【大白话说Java面试题 第97题】【Mysql篇】第27题:说说分库与分表的设计?
java·开发语言·数据库·分布式·mysql·算法
Vertira18 分钟前
VS2022 配置Qt5/6 [已解决]
开发语言·qt
2301_7926748623 分钟前
java学习(day37)
java