Pytorch基础(5)——SOFTMAX回归相关知识

  • 对多维 Tensor 按维度操作

    给定⼀个 Tensor 矩阵 X 。我们可以只对其中同⼀列( dim=0 )或同⼀⾏( dim=1 )的元素求和,并在结果中保留⾏和列这两个维度( keepdim=True )。
    X = torch.tensor([[1, 2, 3], [4, 5, 6]])
    print(X.sum(dim=0, keepdim=True))
    print(X.sum(dim=1, keepdim=True))
    
    # 输出
    tensor([[5, 7, 9]])
    tensor([[ 6],
            [15]])
  •  gather函数

    变量 y_hat 2 个样本在 3 个类别的预测概率,变量 y 是这 2个样本的标签类别。通过使⽤ gather 函数,我们得到了 2 个样本的标签的预测概率。
    y_hat = torch.tensor([[0.1, 0.3, 0.6], [0.3, 0.2, 0.5]])
    y = torch.LongTensor([0, 2])
    y_hat.gather(1, y.view(-1, 1))
    
    # 输出
    tensor([[0.1000],
            [0.5000]])
    下⾯实现了( softmax 回归)交叉熵损失函数。
    def cross_entropy(y_hat, y):
     return - torch.log(y_hat.gather(1, y.view(-1, 1)))

  •  计算准确率

    定义准确率 accuracy 函数。其中 y_hat.argmax(dim=1) 返回矩阵 y_hat 每⾏中最⼤元素的索 引,且返回结果与变量 y 形状相同。相等条件判断式 (y_hat.argmax(dim=1) == y) 是⼀个类型为 ByteTensor Tensor ,我们⽤ float() 将其转 换为值为0 (相等为假)或 1 (相等为真)的浮点型 Tensor
    def accuracy(y_hat, y):
        return (y_hat.argmax(dim=1) == y).float().mean().item()
  • 训练模型 

    num_epochs, lr = 5, 0.1
    
    # 本函数已保存在d2lzh包中⽅便以后使⽤
    def train_ch3(net, train_iter, test_iter, loss, num_epochs,
    batch_size,params=None, lr=None, optimizer=None):
         for epoch in range(num_epochs):
             train_l_sum, train_acc_sum, n = 0.0, 0.0, 0
             for X, y in train_iter:
                 y_hat = net(X)
                 l = loss(y_hat, y).sum()
     
                 # 梯度清零
                 if optimizer is not None:
                     optimizer.zero_grad()
                 elif params is not None and params[0].grad is not None:
                     for param in params:
                         param.grad.data.zero_()
     
                 l.backward()
                 if optimizer is None:
                     d2l.sgd(params, lr, batch_size)
                 else:
                     optimizer.step() # “softmax回归的简洁实现”将⽤到
     
     
                 train_l_sum += l.item()
                 train_acc_sum += (y_hat.argmax(dim=1) == y).sum().item()
                 n += y.shape[0]
             test_acc = evaluate_accuracy(test_iter, net)
             print('epoch %d, loss %.4f, train acc %.3f, test acc %.3f'
                 % (epoch + 1, train_l_sum / n, train_acc_sum / n, test_acc))
    
    train_ch3(net, train_iter, test_iter, cross_entropy, num_epochs,
    batch_size, [W, b], lr)
    
    
    # 输出
    epoch 1, loss 0.7878, train acc 0.749, test acc 0.794
    epoch 2, loss 0.5702, train acc 0.814, test acc 0.813
    epoch 3, loss 0.5252, train acc 0.827, test acc 0.819
    epoch 4, loss 0.5010, train acc 0.833, test acc 0.824
    epoch 5, loss 0.4858, train acc 0.836, test acc 0.815

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值