PyTorch使用笔记

本文介绍如何将神经网络模型放置于GPU上以加速训练过程,使用PyTorch的nn.Sequential构造多层感知器(MLP),并在每个epoch后利用验证集评估模型,以防止过拟合并选择最佳模型。
  1. 将data, target, loss层,神经网络模型放到GPU上!
  2. 在构造模型时,可以使用这种方法,直接使用nn.Sequential来构造!
    这样在forward时可以直接用一个self.model来做!
class MLP(nn.Module):

    def __init__(self):
        super(MLP, self).__init__()

        self.model = nn.Sequential(
            nn.Linear(784, 200),
            nn.ReLU(inplace=True),
            nn.Linear(200, 200),
            nn.ReLU(inplace=True),
            nn.Linear(200, 10),
            nn.ReLU(inplace=True),
        )

    def forward(self, x):
        x = self.model(x)

        return x
  1. 神经网络在训练时可以每经过一个epoch就用训练得到的模型在validation set上进行一下测试,看模型实际效果,从而有效避免过拟合的出现!
  2. 训练时可以每个epoch(或者每隔n个)学习到的模型以及其loss保存下来,然后用val set验证其准确率,最后所有的epoch完成后,从中选择一个效果最好的check point模型进行加载,对test set进行测试看其实际泛化能力,但一定注意test set的数据不参与backward,只是forward
### PyTorch 学习笔记教程 #### 张量 Tensor 的基本操作 PyTorch 是一个基于 Python 的科学计算包,能够替代 Numpy 并充分利用 GPU 的强大性能[^1]。张量 (Tensor) 是 PyTorch 中最基本的数据结构之一。 下面展示了一个简单的例子来创建并调整张量形状: ```python import torch input_tensor = torch.tensor([[1, -0.5], [-1, 3]]) reshaped_input = torch.reshape(input_tensor, (-1, 1, 2, 2)) print(reshaped_input.shape) ``` 这段代码首先定义了一个二维张量 `input_tensor` ,接着通过调用 `reshape()` 方法将其转换成四维张量,并打印其新的尺寸大小。 #### 使用神经网络模块构建模型 为了实现更复杂的机器学习算法,通常会使用预定义好的层来进行快速开发。这里介绍如何利用内置函数轻松搭建自己的神经网络架构: ```python from torch import nn class SimpleModel(nn.Module): def __init__(self): super(SimpleModel, self).__init__() self.relu_layer = nn.ReLU() def forward(self, x): return self.relu_layer(x) model_instance = SimpleModel() output_result = model_instance(reshaped_input) print(output_result) ``` 上述代码片段展示了怎样继承自 `nn.Module` 类来自定义一个新的类 `SimpleModel` 。该类内部包含了激活函数 ReLU 层作为成员变量,在前向传播过程中可以直接应用此层处理输入数据。 #### 验证安装版本号 当完成环境配置之后,可以通过如下方式验证当前使用PyTorch 版本是否正确无误: ```python import torch print(torch.__version__) ``` 这行命令将会输出已成功加载到项目中的 PyTorch 库的具体版本信息[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值