CUDA执行模型

一、CUDA执行模型概述

二、线程束执行

1. 线程束与线程块

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

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

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

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

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

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

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

2. 线程束分化

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

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

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

相关推荐
Filwaod6 分钟前
MCP 接入模式对比:Agent - Gateway - 业务项目 vs Agent - Adapter - 业务项目
java·agent·mcp
kuonyuma14 分钟前
MyBatis入门·注解操作
java·spring boot·mysql·spring·mybatis
字节高级特工18 分钟前
智能指针原理与使用场景全解析
开发语言·c++·算法
码界索隆20 分钟前
Python转Java系列:面向对象基础
java·开发语言·python
逻辑星辰25 分钟前
x-ds-pow-response逆向分析
开发语言·人工智能·python·深度学习·算法
DIY源码阁25 分钟前
JavaSwing酒店管理系统 - MySQL版
java·mysql·eclipse
不恋水的雨44 分钟前
easyexcel快速填充大数据量不覆盖后面的行解决方式
java·excel·poi
AI科技星1 小时前
《全域数学/数术工坊》体系总览
c语言·开发语言·汇编·electron·概率论
范什么特西1 小时前
Maven中dependencies和dependencyManagement区别
java·开发语言·maven
SunnyDays10111 小时前
Java 操作 Word 超链接:添加网页、邮箱、文件和图片链接
java·word·超链接