使用PyTorch构建神经网络(详细步骤讲解+注释版) 02-数据读取与训练

简介: 熟悉基础数据分析的同学应该更习惯使用Pandas库对数据进行处理,此处为了加深对PyTorch的理解,我们尝试使用PyTorch读取数据。这里面用到的包是torch.utils.data.Dataset。在下面的代码中,分别定义了len方法与getitem方法。这两个方法都是python的内置方法,但是对类并不适用。这里通过重写方法使类也可以调用,并且自定义了getitem方法的输出

前面我们已经建立好了一个神经网络的分类器Class。

使用PyTorch构建神经网络(详细步骤讲解+注释版) 01-建立分类器类

下面进行数据的读取与模型训练

1 使用PyTorch对数据处理

熟悉基础数据分析的同学应该更习惯使用Pandas库对数据进行处理,此处为了加深对PyTorch的理解,我们尝试使用PyTorch读取数据。这里面用到的包是torch.utils.data.Dataset。

在下面的代码中,分别定义了len方法与getitem方法。这两个方法都是python的内置方法,但是对类并不适用。这里通过重写方法使类也可以调用,并且自定义了getitem方法的输出


from torch.utils.data import Dataset
class MnistDataset:
    def __init__(self, csv_file):
        self.data = pandas.read_csv(csv_file)
        pass
    def __len__(self):
        return len(self.data)
    def __getitem__(self, index):
        # 预期输出的张量制作
        label = self.data.iloc[index,0]
        target = torch.zeros(10)
        target[label] = 1.0
        # 图像数据标准化
        image_values = torch.FloatTensor(self.data.iloc[index, 1:].values)/255.0
        return label, image_values, target


len方法起到了返回DataFrame大小的作用。


label:获得了指定数据的第一个数值,也就是这个数据的标签;

target:制作了一个维度为10的张量,标签对应的项是1,其他是0。比如,某个手写数据的标签是2,则这个张量是[0, 0, 1, 0, 0, 0, 0, 0, 0, 0]。

image_values:像素输入的值是0-255,这里对像素数据做了标准化,是值位于0-1之间。

在MnistDataset类中,博主也看到有教程为其添加了绘画的功能,这个功能在实现神经网络的过程中,并不会起到实质性作用,但是可能有助于快速查看数据情况,所以我把代码放到这里,很简单大家自行学习就好。


class MnistDataset:
    def plot_image(self, index):
        arr = self.data.iloc[index, 1:].values.reshape(28, 28)
        plt.title("label=" + str(self.data.iloc[index, 0]))
        plt.imshow(arr, interpolation='none', cmap='Blues')
        plt.show()
1


可以使用这个功能查看数据集:


mnist_dataset = MnistDataset('数据集地址')
mnist_dataset.plot_image(123)
1

2

截至目前,MnistDataset这个类的全部代码为


class MnistDataset:
    def __init__(self, csv_file):
        self.data = pandas.read_csv(csv_file)
        pass
    def __len__(self):
        return len(self.data)
    def __getitem__(self, index):
        # 预期输出的张量制作
        label = self.data.iloc[index, 0]
        target = torch.zeros(10)
        target[label] = 1.0
        # 图像数据标准化
        image_values = torch.FloatTensor(self.data.iloc[index, 1:].values) / 255.0
        return label, image_values, target
def plot_image(self, index):
        arr = self.data.iloc[index, 1:].values.reshape(28, 28)
        plt.title("label=" + str(self.data.iloc[index, 0]))
        plt.imshow(arr, interpolation='none', cmap='Blues')
        plt.show()
        pass


这是目前我们所完成的内容(蓝色部分位于上一篇博客)


2beec639d07c4665bffdd071ed4591cb.png




2 模型训练

首先创建一个分类器类

C = Classifier()


在训练过程中,我们可以只训练一轮,也就是训练集中的数据依次传入模型进行训练,也可以训练多轮,即一个数据集都传入一遍之后,在从头重复传入数据进行训练的这个动作。对于描述训练几轮有一个专有名词epochs,在写代码时通常会以这个单词作为变量名。

接下来我们执行三组循环:


epochs = 3
for i in range(epochs):
    print('training epoch', i+1, 'of', epochs)
    for label, image_data_tensor, target_tensor in mnist_dataset:
        C.train(image_data_tensor, target_tensor)
1


在mnist_dataset能够直接取数是因为我们之前定义了getitem方法。以上就是完整的训练过程。在训练时,每当完成一轮或完成10000组数据都会有相应的print(后者来自train方法)。如果我们还想知道这一过程花费的时间,还可以导入time包进行计算。这一部分的完整代码如下。


start_time =time.perf_counter() # 计时开始
C = Classifier()
epochs = 3
for i in range(epochs):
    print('training epoch', i+1, 'of', epochs)
    for label, image_data_tensor, target_tensor in mnist_dataset:
        C.train(image_data_tensor, target_tensor)
end_time =time.perf_counter()
print('完成3个epochs需要的时间是', end_time-start_time)


f7a4789a5f294aa09616bf936f4f953f.png


一般情况下,使用个人电脑进行计算的话,每轮训练一般不超过10分钟。如果购买了Google Colab等付费在线服务器,这一过程还会更快。


3 训练过程可视化

在训练结束之后,如果希望查看训练次数与误差之间的关系,我们可以在Classifier类中定义一个可视化方法。首先在initial下,初始化一个用于记录损失的列表。


class Classifier(nn.Module):
    def __init__(self):
        # 用于展示训练进程的计数器和列表
        self.counter = 0
        self.progress = []


接着在train方法下,每隔10个训练记录一次损失值,每隔10000个输出一次训练个数(也就是对应上面console截图的输出)。


class Classifier(nn.Module):
    def train(self, inputs, targets):
        # 进程可视化数据
        self.counter += 1
        if self.counter % 10 == 0:
            self.progress.append(loss.item())
            pass
        if self.counter % 10000 == 0:
            print("counter = ", self.counter)
            pass



最后,建立一个绘图的方法,使用matplotlib.pyplot(import as plt)绘制散点图。


class Classifier(nn.Module):
    # 训练进程制图
    def plot_progress(self):
        df = pandas.DataFrame(self.progress, columns=['loss'])
        df.plot(ylim=(0, 1.0), figsize=(16, 8), alpha=0.1, marker='.', grid=True, yticks=(0, 0.25, 0.5))
        plt.show()


这里的一些设置主要是控制绘图细节,比如ylim是坐标轴范围,alpha是透明度,yticks是网格位置等。这一部分如有兴趣也可以对matplotlib.pyplot进行专门学习。

在完善了类的相关方法后,再次进行训练就会自动保存误差数据,训练之后,我们使用:


C.plot_progess()
1

就可以把图绘制出来了。

e9583d1d38f345c8862fdb8f2ca686c3.png





可以看出,随着训练次数的增加,损失下降还是比较明显的。


本系列文章使用不断迭代优化代码的方式进行撰写,以模块不断对代码进行补充方便大家理解。如果希望获取完整代码文件,直接文末留言或者到个人博客的资源区进行下载即可。完整代码下载链接

下一篇文章将会讲解如何评价模型表现与提升模型准确率


相关文章
|
9月前
|
前端开发 JavaScript 开发者
JavaScript:构建动态网络的引擎
JavaScript:构建动态网络的引擎
|
9月前
|
机器学习/深度学习 算法 调度
14种智能算法优化BP神经网络(14种方法)实现数据预测分类研究(Matlab代码实现)
14种智能算法优化BP神经网络(14种方法)实现数据预测分类研究(Matlab代码实现)
626 0
|
10月前
|
机器学习/深度学习 数据采集 传感器
【故障诊断】基于matlab BP神经网络电机数据特征提取与故障诊断研究(Matlab代码实现)
【故障诊断】基于matlab BP神经网络电机数据特征提取与故障诊断研究(Matlab代码实现)
289 0
|
8月前
|
机器学习/深度学习 数据可视化 网络架构
PINN训练新思路:把初始条件和边界约束嵌入网络架构,解决多目标优化难题
PINNs训练难因多目标优化易失衡。通过设计硬约束网络架构,将初始与边界条件内嵌于模型输出,可自动满足约束,仅需优化方程残差,简化训练过程,提升稳定性与精度,适用于气候、生物医学等高要求仿真场景。
899 4
PINN训练新思路:把初始条件和边界约束嵌入网络架构,解决多目标优化难题
|
9月前
|
人工智能 监控 数据可视化
如何破解AI推理延迟难题:构建敏捷多云算力网络
本文探讨了AI企业在突破算力瓶颈后,如何构建高效、稳定的网络架构以支撑AI产品化落地。文章分析了典型AI IT架构的四个层次——流量接入层、调度决策层、推理服务层和训练算力层,并深入解析了AI架构对网络提出的三大核心挑战:跨云互联、逻辑隔离与业务识别、网络可视化与QoS控制。最终提出了一站式网络解决方案,助力AI企业实现多云调度、业务融合承载与精细化流量管理,推动AI服务高效、稳定交付。
|
8月前
|
机器学习/深度学习 人工智能 算法
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
320 0
|
9月前
|
机器学习/深度学习 算法 搜索推荐
从零开始构建图注意力网络:GAT算法原理与数值实现详解
本文详细解析了图注意力网络(GAT)的算法原理和实现过程。GAT通过引入注意力机制解决了图卷积网络(GCN)中所有邻居节点贡献相等的局限性,让模型能够自动学习不同邻居的重要性权重。
1542 0
从零开始构建图注意力网络:GAT算法原理与数值实现详解
|
8月前
|
机器学习/深度学习 分布式计算 Java
Java与图神经网络:构建企业级知识图谱与智能推理系统
图神经网络(GNN)作为处理非欧几里得数据的前沿技术,正成为企业知识管理和智能推理的核心引擎。本文深入探讨如何在Java生态中构建基于GNN的知识图谱系统,涵盖从图数据建模、GNN模型集成、分布式图计算到实时推理的全流程。通过具体的代码实现和架构设计,展示如何将先进的图神经网络技术融入传统Java企业应用,为构建下一代智能决策系统提供完整解决方案。
653 0
|
9月前
|
机器学习/深度学习 数据采集 运维
改进的遗传算法优化的BP神经网络用于电厂数据的异常检测和故障诊断
改进的遗传算法优化的BP神经网络用于电厂数据的异常检测和故障诊断
|
9月前
|
机器学习/深度学习 传感器 算法
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
564 2