Pytorch学习 day14(使用GPU进行训练)

使用GPU进行训练,方式一:

  • 需要在网络模型的实例创建处、数据(输入、标签)处、损失函数的实例创建处,更改为.cuda(),代码如下:
  • 注意:只有数据(输入、标签)需要将.cuda()后的重新赋值给原变量名,网络模型和损失函数不需要,这里为了方便记忆,就都重新赋值了
# 网络模型的实例创建处
# 创建网络模型
tudui = Tudui()
tudui = tudui.cuda()

# 数据(输入、标注)处
for data in train_loader:
    inputs, targets = data
    inputs = inputs.cuda()
    targets = targets.cuda()

# 损失函数的实例创建处
# 创建损失函数
loss_fn = nn.CrossEntropyLoss()
loss_fn = loss_fn.cuda()
  • 由下图可知,GPU训练的速度还是很快的:
    在这里插入图片描述
    在这里插入图片描述

使用GPU进行训练,方式二:

  • 需要在一开始定义运行设备,device = torch.device(‘cuda’)
  • 注意:‘cpu’ 表示在cpu上运行,‘cuda’ 表示在gpu上运行,‘cuda:0’ 表示在第一张显卡上运行,‘cuda:1’ 表示在第二张显卡上运行
  • 注意:只有数据(输入、标签)需要将.to(device)后的重新赋值给原变量名,网络模型和损失函数不需要,这里为了方便记忆,就都重新赋值了
  • 并在网络模型的实例创建处、数据(输入、标签)处、损失函数的实例创建处,更改为.to(device),代码如下:
# 设置运行设备
device = torch.device('cuda')

# 网络模型的实例创建处
# 创建网络模型
tudui = Tudui()
tudui = tudui.to(device)

# 损失函数的实例创建处
# 创建损失函数
loss_fn = nn.CrossEntropyLoss()
loss_fn = loss_fn.to(device)

# 数据(输入、标注)处
for data in train_loader:
    inputs, targets = data
    inputs = inputs.to(device)
    targets = targets.to(device)
  • 注意,有的代码会将判断cuda.is_available()放在()中,如下:
  • 表示如果cuda可用就使用gpu,否则就使用cpu
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丿罗小黑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值