Pytorch——多卡GPU训练与单卡GPU训练相互切换

部分深度学习网络默认是多卡并行训练的,由于某些原因,有时需要指定在某单卡上训练,最近遇到一个,这里总结如下。

目录

  • 一、多卡训练
    • [1.1 修改配置文件](#1.1 修改配置文件)
    • [1.2 修改主训练文件](#1.2 修改主训练文件)
    • [1.3 显卡使用情况](#1.3 显卡使用情况)
  • 二、单卡训练
    • [2.1 修改配置文件](#2.1 修改配置文件)
    • [2.2 显卡使用情况](#2.2 显卡使用情况)
  • 三、总结

一、多卡训练

1.1 修改配置文件

1.2 修改主训练文件

上面红框中代码解析:

python 复制代码
if torch.cuda.is_available() and ngpu > 1:         # 当 torch.cuda.is_available() 为真且 ngpu > 1 时              
	model = nn.DataParallel(model, device_ids=list(range(ngpu)))

model = nn.DataParallel(model, device_ids=list(range(ngpu))):

此行代码创建了一个 DataParallel包装器,用于在多个GPU上并行处理神经网络模型。DataParallel 是 PyTorch 中的一个模块,它可以将输入数据分割并发送到不同的GPU进行处理,然后汇总结果。

model:要并行化的神经网络模型。

device_ids=list(range(ngpu)):指定要使用的GPU。在这里,它使用了所有可用的GPU,数量上限为指定的 ngpu。

1.3 显卡使用情况

二、单卡训练

2.1 修改配置文件

2.2 显卡使用情况

修改好后开始训练,查看显卡使用情况:

三、总结

以上就是多卡GPU训练与单卡GPU训练相互切换的操作过程,希望能帮到你,谢谢!

相关推荐
陈增林6 分钟前
基于深度学习的工件检测系统设计与实现
人工智能·深度学习
lizz317 分钟前
离线服务器Python环境配置指南
运维·服务器·python
小乐爱技术8 分钟前
使用亮数据代理IP+Python爬虫批量爬取招聘信息训练面试类AI智能体(实战指南)
爬虫·python·tcp/ip·其他
安审若无18 分钟前
Base64加密解密
python·密码学
灬0灬灬0灬19 分钟前
掩膜合并代码
开发语言·python
Fibocom广和通19 分钟前
【无标题】
人工智能·computex 2025
愿做无知一猿23 分钟前
【JAVA】中文我该怎么排序?
java·开发语言·python
LIUDAN'S WORLD23 分钟前
大模型微调与高效训练
人工智能·python
慌糖25 分钟前
[特殊字符] 遇见Flask
后端·python·flask
Johny_Zhao40 分钟前
VMware Workstation 部署企业级 AD 域、DNS、DHCP 系统操作指南
网络·人工智能·网络安全·信息安全·云计算·ad·dns·dhcp·系统运维·itsm