torch.cuda¶
此软件包增加了对 CUDA 张量类型的支持。
它实现与 CPU 张量相同的功能,但它们使用 用于计算的 GPU。
它是延迟初始化的,因此您始终可以导入它,并用于确定您的系统是否支持 CUDA。
CUDA 语义 有更多关于使用 CUDA 的详细信息。
选择给定流的 context-manager。 |
|
检查两个设备之间是否可以进行对等访问。 |
|
返回指向当前 cuBLAS 句柄cublasHandle_t指针 |
|
返回当前所选设备的索引。 |
|
检索 CUDA 运行时 API 模块。 |
|
更改所选设备的 context-manager 。 |
|
返回可用的 GPU 数量。 |
|
将当前设备更改为给定对象的设备的上下文管理器。 |
|
返回编译此库的 CUDA 架构列表。 |
|
获取设备的 cuda 功能。 |
|
获取设备的名称。 |
|
获取设备的属性。 |
|
返回此库编译时使用的 NVCC gencode 标志。 |
|
返回 cuda 同步操作的调试模式的当前值。 |
|
初始化 PyTorch 的 CUDA 状态。 |
|
Force 在 CUDA IPC 释放 GPU 内存后收集 GPU 内存。 |
|
返回一个布尔值,指示 CUDA 当前是否可用。 |
|
返回 PyTorch 的 CUDA 状态是否已初始化。 |
|
返回上一个采样周期内读取或写入全局(设备)内存的时间百分比,如 nvidia-smi 给出。 |
|
设置当前设备。 |
|
设置当前流。这是一个用于设置流的包装器 API。 |
|
设置 cuda 同步操作的调试模式。 |
|
环绕选择给定流的 Context-manager StreamContext。 |
|
等待 CUDA 设备上所有流中的所有内核完成。 |
|
返回上一个采样周期中一个或多个内核在 GPU 上执行的时间百分比,如 nvidia-smi 给出。 |
|
返回 GPU 传感器的平均温度,以摄氏度为单位。 |
|
返回 GPU 传感器的平均功耗,以 mW (MilliWatts) 为单位 |
|
返回 nvidia-smi 给出的上一个采样周期内 GPU SM 的时钟速度(以赫兹赫兹为单位)。 |
|
当设备内存不足时引发异常 |
随机数生成器¶
将指定 GPU 的随机数生成器状态作为 ByteTensor 返回。 |
|
返回表示所有设备的随机数状态的 ByteTensor 列表。 |
|
设置指定 GPU 的随机数生成器状态。 |
|
设置所有设备的随机数生成器状态。 |
|
设置用于为当前 GPU 生成随机数的种子。 |
|
设置用于在所有 GPU 上生成随机数的种子。 |
|
将生成随机数的种子设置为当前 GPU 的随机数。 |
|
将用于生成随机数的种子设置为所有 GPU 上的随机数。 |
|
返回当前 GPU 的当前随机种子。 |
通信集体¶
将张量广播到指定的 GPU 设备。 |
|
将一系列张量广播到指定的 GPU。 |
|
对来自多个 GPU 的张量求和。 |
|
将张量分散到多个 GPU 上。 |
|
从多个 GPU 设备收集张量。 |
图形(测试版)¶
如果当前 CUDA 流上正在进行 CUDA 图形捕获,则返回 True,否则返回 False。 |
|
返回一个不透明的令牌,该令牌表示图形内存池的 ID。 |
|
CUDA 图形的包装器。 |
|
将 CUDA 工作捕获到对象中 |
|
内存管理¶
释放缓存分配器当前持有的所有未占用的缓存内存,以便这些内存可以在其他 GPU 应用程序中使用并在 nvidia-smi 中可见。 |
|
返回给定设备正在运行的进程及其 GPU 内存使用情况的人类可读打印输出。 |
|
使用 cudaMemGetInfo 返回给定设备的全局可用内存和总 GPU 内存。 |
|
返回给定设备的 CUDA 内存分配器统计信息字典。 |
|
返回给定设备的当前内存分配器统计信息的人类可读打印输出。 |
|
返回所有设备上的 CUDA 内存分配器状态的快照。 |
|
返回给定设备的张量占用的当前 GPU 内存(以字节为单位)。 |
|
返回给定设备的张量占用的最大 GPU 内存(以字节为单位)。 |
|
重置跟踪给定设备的张量占用的最大 GPU 内存的起点。 |
|
返回由缓存分配器为给定设备管理的当前 GPU 内存(以字节为单位)。 |
|
返回给定设备的缓存分配器管理的最大 GPU 内存(以字节为单位)。 |
|
设置进程的内存分数。 |
|
重置跟踪给定设备的缓存分配器管理的最大 GPU 内存的起点。 |
|
重置 CUDA 内存分配器跟踪的 “峰值” 统计数据。 |
|
使用 CUDA 内存分配器执行内存分配。 |
|
删除使用 CUDA 内存分配器分配的内存。 |
|
返回一个字符串,描述由 设置的活动分配器后端。 |
|
从 so 文件加载的 CUDA 内存分配器。 |
|
将当前使用的内存分配器更改为提供的内存分配器。 |
|
MemPool 表示缓存分配器中的内存池。 |
|
MemPoolContext 保存当前活动的池并存储前一个池。 |
- 类 torch.cuda 中。use_mem_pool(pool, device=None)[来源]¶
将分配路由到给定池的上下文管理器。
- 参数
pool (torch.cuda.MemPool) – 一个要激活的 MemPool 对象,以便 allocations 路由到此池。
device (torch.device 或 int,可选) – 所选设备。在 当前设备,由
, 给出 if
is (默认)。
None
NVIDIA 工具扩展 (NVTX)¶
描述在某个时间点发生的瞬时事件。 |
|
将范围推送到嵌套范围 span 堆栈上。 |
|
从一堆嵌套范围 span 中弹出一个范围。 |
|
上下文管理器 / 装饰器,在其范围的开头推送 NVTX 范围,并在末尾弹出它。 |
Jiterator(测试版)¶
为 elementwise op 创建一个 jiterator 生成的 cuda 内核。 |
|
为支持返回一个或多个输出的元素运算创建一个 jiterator 生成的 cuda 内核。 |