IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Pytorch基础操作 —— 2.数据与模型在CPU与GPU之间的拷贝与传递 -> 正文阅读

[人工智能]Pytorch基础操作 —— 2.数据与模型在CPU与GPU之间的拷贝与传递

GPU 与 CPU 的运算对比

首先不是所有的电脑都有GPU,我们这里的GPU要强调,必须是 Nvidia 家的显卡,所以你无论是Intel的独显,还是AMD家的独显,都没法使用到以下的特性加速你的计算过程,那就更不要提什么核显这种了。

GPU相对CPU来说更擅长科学计算,这是因为GPU舍弃,或大大简化了CPU需要负担的复杂任务执行的Control单元,而同时有更多负责加减乘除运算的ALU单元。

在这里插入图片描述

为了更直观对比两者在计算性能上的差异,我们做一个实验。

import torch
import time


with torch.no_grad():
    # 程序计时开始
    time_start = time.time()

    tensor1 = torch.randn(100, 1000, 1000)
    tensor2 = torch.randn(100, 1000, 1000)

    result = tensor1 * tensor2
    for i in range(1000):
        result = result + tensor1 * tensor2

    # 程序片段后插入以下两行
    time_end = time.time()
    print('Time cost on CPU = %fs' % (time_end - time_start))


    # 程序计时开始
    time_start = time.time()

    tensor1 = torch.randn(100, 1000, 1000).cuda()
    tensor2 = torch.randn(100, 1000, 1000).cuda()

    result = tensor1 * tensor2
    for i in range(1000):
        result = result + tensor1 * tensor2

    # 程序片段后插入以下两行
    time_end = time.time()
    print('Time cost on GPU = %fs' % (time_end - time_start))

这是一个程序计时,我们模拟的是两个高维度的张量数据的计算,这种运算规模在亿级以上。使用CPU的计算结果是:

Time cost on CPU = 178.318684s

而到了GPU上,则表现为

Time cost on GPU = 4.024427s

我现在使用的设备主要是Dell G7,主要的配置是

在这里插入图片描述

可以看到GPU其实是一颗很羸弱的1060,但是同样维度的张量计算却比CPU块了不止一倍。这就是GPU的恐怖计算能力。

张量或模型所在的设备位置

我们在创建了张量,或者网络模型后,有时候会好奇这些模型、数据存储在哪里,所以可以通过下面这条命令来查看。

tensor.device

这对于模型也是一样的。

next(model.parameters()).device

我们来看看怎么用的

import torch


class UserDefinedModel(torch.nn.Module):

    def __init__(self):
        super().__init__()
        self.linear = torch.nn.Linear(100, 30)

    def forward(self, data):
        return self.linear(data)


tensor1 = torch.randn(100, 1000, 1000)
tensor2 = tensor1.cuda()

cpu_model = UserDefinedModel()
gpu_model = UserDefinedModel().cuda()

print("tensor on", tensor1.device)
print("tensor on", tensor2.device)

print("model on", next(cpu_model.parameters()).device)
print("model on", next(gpu_model.parameters()).device)

输出结果:

tensor on cpu
tensor on cuda:0
model on cpu
model on cuda:0

检查自己的设备是否支持CUDA

现在你可能会问,我有什么办法可以知道自己的设备是否支持CUDA呢?你可以执行下面这个命令来获得自己的设备支持情况。

import torch

if torch.cuda.is_available():
	print("CUDA available")
else:
	print("CPU only")

把数据或模型从CPU转到GPU上

由于 torch 同时支持GPU与CPU计算, 这使得它的应用性可以更广泛的覆盖到不同的设备上. 你可以根据自己设备的特点, 来决定如何更好的使用 torch。

目前对于科学计算来说,Nvidia家的显卡能更好的支持科学计算, 所以自然而然的, 当需要消耗大量资源的矩阵计算出现时, 最好是把这类计算全部放到GPU上更为合算. 所以我们可以通过以下命令,把数据写入到GPU的运存上

拷贝方法很简单,可以这样做:

CPU → \rightarrow GPU

if torch.cuda.is_available():
  tensor = tensor.cuda()

你也可以这样:

import torch

# 检查支持什么设备
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")

# 把数据拷贝到适合的设备上
tensor1 = torch.randn(10, 10).to(device)
print(tensor1.device)

相对来说,上面的方法相对比较温和一些

把数据或模型拷贝到多张GPU上

如果你有多张GPU,通常是渲染工作站,有多过一张的CUDA卡,那么也可以通过指定的形式,把数据传拷贝到指定的 GPU 设备的运存上

	tensor_cuda_0 = tensor.to('cuda:0')
	tensor_cuda_1 = tensor.to('cuda:1')
	tensor_cuda_2 = tensor.to('cuda:2')
	...

也可以使用上面提到过的device方法

import torch

# 检查支持什么设备
device1 = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
device2 = torch.device("cuda:1" if torch.cuda.is_available() else "cpu")
device3 = torch.device("cuda:2" if torch.cuda.is_available() else "cpu")
device4 = torch.device("cuda:3" if torch.cuda.is_available() else "cpu")
...

tensor_cuda_0 = tensor.to(device1)
tensor_cuda_1 = tensor.to(device2)
tensor_cuda_2 = tensor.to(device3)
...

或者直接用.cuda()

tensor1 = torch.randn(10, 10).cuda()

这个指令会把数据传送到默认的CUDA设备上,如果有多块设备要制定,可以这样

tensor1 = torch.randn(10, 10).cuda(0)
tensor2 = torch.randn(10, 10).cuda(1)
tensor3 = torch.randn(10, 10).cuda(2)
...

把数据或模型拷贝到回CPU上

如果想要把数据从 GPU 拷贝到回 CPU 的运存上,那么就执行如下命令:

	tensor = tensor.to('cpu')

除此以外,目前的torch还支持使用 cpu() ,以函数的形式进行拷贝。

	tensor = tensor.cpu()
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-10-07 13:51:15  更:2021-10-07 13:53:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 14:26:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码