PyTorch框架绘制loss和accuracy曲线

train_losses = []
train_acces = []
# 用数组保存每一轮迭代中,在测试数据上测试的损失值和精确度,也是为了通过画图展示出来。
eval_losses = []
eval_acces = []

for e in range(100):


    # 4.1==========================训练模式==========================
    train_loss = 0
    train_acc = 0
    model.train()   # 将模型改为训练模式

    # 每次迭代都是处理一个小批量的数据,batch_size是64
    for im, label in train_data:
        im = Variable(im)
        label = Variable(label)

        # 计算前向传播,并且得到损失函数的值
        out = model(im)

        loss = criterion(out, label)

        # 反向传播,记得要把上一次的梯度清0,反向传播,并且step更新相应的参数。
        optimizer.zero_grad()
        loss.backward()
        optimizer.step()

        # 记录误差
        train_loss += loss.item()

        # 计算分类的准确率
        out_t = out.argmax(dim=1) #取出预测的最大值
        num_correct = (out_t == label).sum().item()
        acc = num_correct / im.shape[0]
        train_acc += acc

    train_losses.append(train_loss / len(train_data))
    train_acces.append(train_acc / len(train_data))



    # 4.2==========================每次进行完一个训练迭代,就去测试一把看看此时的效果==========================
    # 在测试集上检验效果
    eval_loss = 0
    eval_acc = 0
    model.eval()  # 将模型改为预测模式

    # 每次迭代都是处理一个小批量的数据,batch_size是128
    for im, label in test_data:
        im = Variable(im)  # torch中训练需要将其封装即Variable,此处封装像素即784
        label = Variable(label)  # 此处为标签

        out = model(im)  # 经网络输出的结果
        loss = criterion(out, label)  # 得到误差

        # 记录误差
        eval_loss += loss.item()

        # 记录准确率
        out_t = out.argmax(dim=1)  # 取出预测的最大值的索引
        num_correct = (out_t == label).sum().item()  # 判断是否预测正确
        acc = num_correct / im.shape[0]  # 计算准确率
        eval_acc += acc

    eval_losses.append(eval_loss / len(test_data))
    eval_acces.append(eval_acc / len(test_data))
    print('epoch: {}, Train Loss: {:.6f}, Train Acc: {:.6f}, Eval Loss: {:.6f}, Eval Acc: {:.6f}'
          .format(e, train_loss / len(train_data), train_acc / len(train_data),
                  eval_loss / len(test_data), eval_acc / len(test_data)))

plt.plot(np.arange(len(train_losses)), train_losses,label="train loss")

plt.plot(np.arange(len(train_acces)), train_acces, label="train acc")

plt.plot(np.arange(len(eval_losses)), eval_losses, label="valid loss")

plt.plot(np.arange(len(eval_acces)), eval_acces, label="valid acc")
plt.legend() #显示图例
plt.xlabel('epoches')
#plt.ylabel("epoch")
plt.title('Model accuracy&loss')
plt.show()

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 Matplotlib 库在 Python绘制 loss 和 epoch 曲线。首先,需要在代码中导入 Matplotlib,然后通过记录 loss 和 epoch 的数值并将其作为 Matplotlib 的输入数据,最后调用 plot 函数绘制曲线。例如: ``` import matplotlib.pyplot as plt epochs = [1, 2, 3, 4, 5] loss = [0.2, 0.15, 0.1, 0.05, 0.01] plt.plot(epochs, loss, 'r') plt.xlabel('Epochs') plt.ylabel('Loss') plt.title('Loss vs. Epochs') plt.show() ``` 这将绘制红色的 loss 和 epoch 曲线。 ### 回答2: Python是一种高级的编程语言,适用于各种领域,包括机器学习和深度学习。当我们训练模型时,我们通常需要了解模型的性能如何随时间推移而变化。为了实现这一目标,我们在代码中添加了可视化损失和epoch曲线的功能。下面将详细介绍如何使用Python绘制loss和epoch曲线。 首先,我们需要从训练模型的程序中获取损失和epoch数据。我们可以使用Python的numpy库来存储这些数据。在训练期间,我们可以将损失和epoch数据发送到numpy数组中。通常,我们将损失和epoch数据保存在csv文件中,以备将来使用。 接下来,我们需要将损失和epoch数据可视化。我们可以使用Python的matplotlib库来实现可视化。对于简单的可视化,我们可以使用plt.plot()函数将损失和epoch数据传递给Matplotlib。在图表上,将显示损失和epoch的变化趋势。 如果我们想更加详细地研究模型的性能,并将损失和epoch图表细化到数据点级别,我们可以使用Seaborn库。Seaborn库建立在Matplotlib库之上,并提供了更加高效和美观的可视化效果。 一些其他的Python库,如Plotly和Bokeh,提供了交互式的数据可视化,使用户能够从数据中获取更多信息。 总的来说,Python的numpy,Matplotlib,Seaborn等开源库可以帮助我们对机器学习和深度学习的模型进行可视化,以进一步优化模型性能。可视化数据可以帮助我们更好地理解模型的运行和优化,以便在竞争激烈的数据科学和机器学习领域中保持竞争优势。 ### 回答3: Python是一种高级编程语言,其简单易学、易于阅读和有效地处理数据,使其成为机器学习和深度学习领域的流行语言。在训练深度学习模型时,监控模型表现的指标非常重要。通常,人们使用lossaccuracy来监测模型的表现,其中loss表示在一次迭代中预测值与实际值之间的误差。 在机器学习中,模型的loss通常会在每个epoch中被计算并记录下来。这些数据需要可视化来更好地理解模型表现。Python提供了一种简单而有效的方法来绘制loss和epoch曲线,这是使用matplotlib库。 首先,我们需要在训练过程中记录每个epoch中的loss。 这可以通过以下方式实现: history = model.fit(X_train, y_train, epochs=10, validation_data=(X_val, y_val)) loss = history.history['loss'] val_loss = history.history['val_loss'] 其中,history是模型训练的历史记录,而loss和val_loss分别是训练集和验证集中的loss。 接下来,我们可以使用matplotlib库来绘制loss和epoch曲线,并添加必要的标签和标题。示例代码如下所示: import matplotlib.pyplot as plt epochs = range(1, len(loss) + 1) plt.plot(epochs, loss, 'bo', label='Training loss') plt.plot(epochs, val_loss, 'b', label='Validation loss') plt.title('Training and Validation Loss') plt.xlabel('Epochs') plt.ylabel('Loss') plt.legend() plt.show() 此代码将绘制一个图表,其中包含两个曲线:蓝色圆点表示训练集的loss,而蓝色线表示验证集的loss。通过图表,我们可以看出模型是否过度拟合,以及我们需要对其进行调整。 总之,通过Python和matplotlib库,绘制loss和epoch曲线是一项简单而重要的任务,它可以帮助我们监视和优化机器学习模型的性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值