pytorch中model.train(),model.eval() 和 torch.no_grad()的区别

部署运行你感兴趣的模型镜像

model.train()

model.train()的作用是启用 Batch NormalizationDropout

如果模型中有BN层或Dropout层,model.train()是保证训练时BN层能够用到每一批数据的均值和方差,对于Dropoutmodel.train()是随机取一部分网络连接来训练更新参数。

注: model.traian()放置位置

model.train() # 错误的位置
for batch_idx, (data, target) in experiment.batch_loop(iterable=train_loader):
    	# model.train() # 正确的位置,保证每一个batch都能进入model.train()的模式

model.eval()

model.eval()的作用是在测试时不启用Batch NormalizationDropout

在测试时,model.eval()是保证BN层能够用全部训练数据的均值和方差,即测试过程中要保证BN层的均值和方差不变;对于Dropoutmodel.eval()是利用到了所有网络连接,即不进行随机舍弃神经元。

注:BN或者dropout里面都会有一个self.is_training,训练时和测试时使用的参数is_training分别为TrueFalse

with torch.no_grad()

eval模式下不会影响各层的梯度计算,即gradient计算和存储与training模式一样,只是不进行反向传播,with torch.no_grad()则主要是用于停止autograd模块的工作,以起到加速和节省显存的作用。它的作用是将该with语句包裹起来的部分停止梯度的更新,从而节省了GPU算力和显存,但是并不会影响dropout和BN层的行为

如果不在意显存大小和计算时间的话,仅仅使用model.eval()已足够得到正确的validation/test的结果;而with torch.no_grad()则是更进一步加速和节省gpu空间(因为不用计算和存储梯度),从而可以更快计算,也可以跑更大的batch来测试

参考
Pytorch:model.train()和model.eval()用法和区别,以及model.eval()和torch.no_grad()的区别

您可能感兴趣的与本文相关的镜像

PyTorch 2.5

PyTorch 2.5

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

`pytorch_model.bin` 文件通常是 PyTorch 保存的预训练模型的权重文件。以下是使用它的常见步骤: ### 1. 安装必要的库 确保已经安装了 PyTorch 相关依赖库,若未安装,可使用以下命令安装: ```bash pip install torch ``` ### 2. 定义模型结构 在加载模型权重之前,需要先定义与保存模型时相同的模型结构。例如,定义一个简单的全连接神经网络: ```python import torch import torch.nn as nn class SimpleNet(nn.Module): def __init__(self): super(SimpleNet, self).__init__() self.fc1 = nn.Linear(10, 20) self.fc2 = nn.Linear(20, 1) def forward(self, x): x = torch.relu(self.fc1(x)) x = self.fc2(x) return x model = SimpleNet() ``` ### 3. 加载模型权重 使用 `torch.load` 函数加载 `pytorch_model.bin` 文件中的权重,并使用 `model.load_state_dict` 方法将权重加载到模型中: ```python # 加载权重 state_dict = torch.load('pytorch_model.bin') # 将权重加载到模型中 model.load_state_dict(state_dict) ``` ### 4. 使用模型进行推理 加载权重后,就可以使用模型进行推理了。将模型设置为评估模式,然后输入数据进行推理: ```python # 将模型设置为评估模式 model.eval() # 生成一些输入数据 input_data = torch.randn(1, 10) # 进行推理 with torch.no_grad(): output = model(input_data) print(output) ``` ### 注意事项 - **模型结构匹配**:加载权重时,模型结构必须与保存权重时的模型结构完全一致,否则会报错。 - **设备一致性**:如果保存的权重是在 GPU 上训练的,加载时需要确保模型数据都在相同的设备(GPU 或 CPU)上。可以使用 `model.to(device)` `input_data.to(device)` 将模型数据移动到指定设备。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Fighting_1997

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

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

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

打赏作者

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

抵扣说明:

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

余额充值