PyTorch初学者:损失函数中的类型错误。

huangapple go评论77阅读模式
英文:

Pytorch Beginner: TypeError in loss function

问题

I'm a beginner in pytorch. I ran into this RuntimeError and I'm struggling to resolve it.
It says that the "result type" of the loss function is Float and cannot be cast to Long.
I have tried casting from float32 to LongTensor before the loss function runs, which resulted in another error inside the model ("RuntimeError: mat1 and mat2 must have the same dtype").
I do not know how to resolve this Problem.

This is my code:

# 设置损失函数
loss_fn = nn.BCEWithLogitsLoss()
# 随机种子
torch.manual_seed = RANDOM_SEED
torch.cuda.manual_seed = RANDOM_SEED

# 迭代次数
epochs = 1000

# 将数据发送到设备
X_train, X_test = X_train.to(device), X_test.to(device)
y_train, y_test = y_train.to(device), y_test.to(device)
# X_train, X_test = X_train.long(), X_test.long()
# y_train, y_test = y_train.long(), y_test.long()


# 训练和测试循环
for epoch in range(epochs):
  model_0.train()
  
  # 1. 前向传播 (logits -> prob -> label)
  y_logits = model_0(X_train).squeeze()
  y_pred = torch.round(torch.sigmoid(y_logits))

  # 2. 计算损失和准确率
  loss = loss_fn(y_logits,
                 y_train)
  acc = acc_fn(y_pred,
               y_train.int())

  # 3. 梯度清零
  optimizer.zero_grad()

  # 4. 损失反向传播 (执行反向传播)
  loss.backward()

  # 5. 优化器中的梯度下降步骤
  optimizer.step() 

  ### 测试
  model_0.eval()
  with torch.inference_mode():
    # 1. 前向传播
    test_logits = model_0(X_test).squeeze()
    test_pred = torch.round(torch.sigmoid(test_logits))

    # 2. 计算测试损失
    test_loss = loss_fn(test_logits,
                        y_test)
    test_acc = acc_fn(test_pred,
                      y_test)
    
    if epoch % 100 == 0:
      ep = str(epoch).zfill(4)
      print(f"Epoch: {ep} | Loss: {loss:.5f}, Acc: {acc:.2f}% | Test loss: {test_loss:.5f}, Test acc: {test_acc:.2f}%")

This is the error message I get:

RuntimeError                              Traceback (most recent call last)
<ipython-input-19-e09e5cb6e9d7> in <cell line: 13>()
     19 
     20   # 2. Calculate loss and accuracy
---> 21   loss = loss_fn(y_logits,
     22                  y_train)
     23   acc = acc_fn(y_pred,

2 frames
/usr/local/lib/python3.9/dist-packages/torch/nn/functional.py in binary_cross_entropy_with_logits(input, target, weight, size_average, reduce, reduction, pos_weight)
   3163         raise ValueError("Target size ({}) must be the same as input size ({})".format(target.size(), input.size()))
   3164 
-> 3165     return torch.binary_cross_entropy_with_logits(input, target, weight, pos_weight, reduction_enum)
   3166 
   3167 

RuntimeError: result type Float can't be cast to the desired output type Long

Runtime Error Screenshot

英文:

I'm a beginner in pytorch. I ran into this RuntimeError and I'm struggling to resolve it.
It says that the "result type" of the loss function is Float and cannot be cast to Long.
I have tried casting from float32 to LongTensor before the loss function runs, which resulted in another error inside the model("RuntimeError: mat1 and mat2 must have the same dtype").
I do not know how to resolve this Problem.

This is my code:

# Setup loss function
loss_fn = nn.BCEWithLogitsLoss()
# Random Seed
torch.manual_seed = RANDOM_SEED
torch.cuda.manual_seed = RANDOM_SEED

# Epochs
epochs = 1000

# Send data to device
X_train, X_test = X_train.to(device), X_test.to(device)
y_train, y_test = y_train.to(device), y_test.to(device)
# X_train, X_test = X_train.long(), X_test.long()
# y_train, y_test = y_train.long(), y_test.long()


# Training and testing loop
for epoch in range(epochs):
  model_0.train()
  
  # 1. Forward pass (logits -&gt; prob -&gt; label)
  y_logits = model_0(X_train).squeeze()
  y_pred = torch.round(torch.sigmoid(y_logits))

  # 2. Calculate loss and accuracy
  loss = loss_fn(y_logits,
                 y_train)
  acc = acc_fn(y_pred,
               y_train.int())

  # 3. Zero gradients
  optimizer.zero_grad()

  # 4. Loss backward (perform backpropagation)
  loss.backward()

  # 5. Optimizer step in gradient descent
  optimizer.step() 

  ### Testing
  model_0.eval()
  with torch.inference_mode():
    # 1. Forward pass
    test_logits = model_0(X_test).squeeze()
    test_pred = torch.round(torch.sigmoid(test_logits))

    # 2. Calculate test loss
    test_loss = loss_fn(test_logits,
                        y_test)
    test_acc = acc_fn(test_pred,
                      y_test)
    
    if epoch % 100 == 0:
      ep = str(epoch).zfill(4)
      print(f&quot;Epoch: {ep} | Loss: {loss:.5f}, Acc: {acc:.2f}% | Test loss: {test_loss:.5f}, Test acc: {test_acc:.2f}%&quot;)

This is the error message I get:

RuntimeError                              Traceback (most recent call last)
&lt;ipython-input-19-e09e5cb6e9d7&gt; in &lt;cell line: 13&gt;()
     19 
     20   # 2. Calculate loss and accuracy
---&gt; 21   loss = loss_fn(y_logits,
     22                  y_train)
     23   acc = acc_fn(y_pred,

2 frames
/usr/local/lib/python3.9/dist-packages/torch/nn/functional.py in binary_cross_entropy_with_logits(input, target, weight, size_average, reduce, reduction, pos_weight)
   3163         raise ValueError(&quot;Target size ({}) must be the same as input size ({})&quot;.format(target.size(), input.size()))
   3164 
-&gt; 3165     return torch.binary_cross_entropy_with_logits(input, target, weight, pos_weight, reduction_enum)
   3166 
   3167 

RuntimeError: result type Float can&#39;t be cast to the desired output type Long

Runtime Error Screenshot

答案1

得分: 0

是的,这很令人困惑。实际上,它需要的都是浮点数。您可以像这样将它们传递给浮点数:y_train.float()

英文:

Yes, this is very confusing. Actually what it wants are both in floats. You can pass then to float just using samething like this: y_train.float()

huangapple
  • 本文由 发表于 2023年4月11日 05:12:33
  • 转载请务必保留本文链接:https://go.coder-hub.com/75980779.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定