CUDA执行模型

一、CUDA执行模型概述

二、线程束执行

1. 线程束与线程块

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

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

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

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

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

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

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

2. 线程束分化

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

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

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

相关推荐
老毛肚5 分钟前
Spring boot 特性和自写Reids组件
java·spring boot·后端
小a杰.13 分钟前
Ascend C算子开发实战 - 从零开始写算子
c语言·开发语言
雪度娃娃15 分钟前
Asio异步读写——连接的安全回收问题
开发语言·c++·安全·php
baivfhpwxf202320 分钟前
c# 中对像之间频繁的转换会慢吗?
开发语言·c#
极光代码工作室21 分钟前
基于SpringBoot的课程管理系统
java·springboot·web开发·后端开发
SilentSamsara21 分钟前
concurrent.futures 实战:进程池与线程池的统一抽象
运维·开发语言·python·青少年编程
JustNow_Man24 分钟前
【opencode】安装使用daytona沙箱插件
android·java·javascript
不吃土豆的马铃薯27 分钟前
Spdlog 进阶:日志基本控制、日志格式控制、异步记录器
linux·服务器·开发语言·前端·c++
武子康1 小时前
Java-05 深入浅出 MyBatis动态SQL与参数拼接完全指南
java·spring boot·后端
水木流年追梦1 小时前
大模型入门-大模型的推理策略
开发语言·python·算法·正则表达式·prompt