当前位置:   article > 正文

pytorch学习笔记(三)用nn.cross_entropy所遇到的问题_nn.cross_entropy axis

nn.cross_entropy axis

Mnist数据集的图片尺寸一般是28*28 = 784,这里模拟一下搭建一个神经元的网络来进行预测和loss的计算,代码如下。

import torch
from torch import nn
import math
import torch.nn.functional as F

class Mnist_net(nn.Module):
    def __init__(self):
        super().__init__()
        self.weights = nn.Parameter(torch.randn(784,10)/math.sqrt(784))
        self.bias = nn.Parameter(torch.zeros(10))

    def forward(self,xb):
        xb = xb@self.weights +self.bias
        return xb

model = Mnist_net()
loss_func = F.cross_entropy
xb = torch.randn(2,784)
yb = torch.tensor([1,1])
print ("model(xb):",model(xb))
print ("yb:",yb)
loss = loss_func(model(xb),yb)
print ("loss:",loss)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

这里要注意的是yb是实际输出的标注,model(xb)是预测的输出,这里yb和model(xb)是不同的尺寸,如下。

model(xb): tensor([[ 0.3825, -0.0071,  0.4110, -0.0534, -0.3756,  0.7349, -3.1753,  0.7359,
         -0.1801,  0.1951],
        [-1.4873,
  • 1
  • 2
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/511638
推荐阅读
相关标签
  

闽ICP备14008679号