pytorch, как я могу сделать одинаковый размер тензорной модели (x) и ответа (x)? - PullRequest
0 голосов
/ 01 декабря 2018

Я пытаюсь сделать простую линейную модель для прогнозирования параметров формулы.

y = 3 * x1 + x2 - 2 * x3

К сожалению,Есть некоторые проблемы, когда я пытаюсь вычислить потери.

def answer(x):
return 3 * x[:,0] + x[:,1] - 2 * x[:,2]


def loss_f(x):  

y = answer(x)
y_hat = model(x)    
loss = ((y - y_hat).pow(2)).sum() / x.size(0)

return loss

Когда я устанавливаю batch_size = 3, размер каждого результата отличается

x = torch.randn(3,3)
answer(x)
tensor([ 2.0201, -3.8354,  2.0059])

model(x)
tensor([[ 0.2085],
    [-0.0670],
    [-1.3635]], grad_fn=<ThAddmmBackward>)

answer(x.data).size()
torch.Size([3])
model(x.data).size()
torch.Size([3, 1])

Я думаю, что вещаниеприменяется автоматически.

loss = ((y - y_hat).pow(2)).sum() / x.size(0)

Как я могу сделать одинаковый размер двух тензоров?Спасибо
Это мой код

import torch
import torch.nn as nn
import torch.optim as optim

class model(nn.Module):

    def __init__(self, input_size, output_size):
        super(model, self).__init__()

        self.linear = nn.Linear(input_size, output_size)

        def forward(self, x):

        y = self.linear(x)

        return y

model = model(3,1)
optimizer = optim.SGD(model.parameters(), lr = 0.001, momentum=0.1)

print('Parameters : ')
for p in model.parameters():
    print(p)

print('')
print('Optimizer : ')
print(optimizer)

def generate_data(batch_size):
    x = torch.randn(batch_size, 3)

    return x

def answer(x):

    return 3 * x[:,0] + x[:,1] - 2 * x[:,2]

def loss_f(x):

    y = answer(x)
    y_hat = model(x)

    loss = ((y - y_hat).pow(2)).sum() / x.size(0)

    return loss

x = torch.randn(3,3)
print(x)
x = torch.FloatTensor(x)

batch_size = 3
epoch_n = 1000
iter_n = 100

for epoch in range(epoch_n):
    avg_loss = 0

    for i in range(iter_n):
        x = torch.randn(batch_size, 3)

        optimizer.zero_grad()
        loss = loss_f(x.data)
        loss.backward()
        optimizer.step()

        avg_loss += loss

    avg_loss = avg_loss / iter_n

    x_valid = torch.FloatTensor([[1,2,3]])
    y_valid = answer(x_valid)

    model.eval()
    y_hat = model(x_valid)
    model.train()

    print(avg_loss, y_valid.data[0], y_hat.data[0])

    if avg_loss < 0.001:
        break

1 Ответ

0 голосов
/ 01 декабря 2018

Вы можете использовать Tensor.view

https://pytorch.org/docs/stable/tensors.html#torch.Tensor.view

Так что что-то вроде

answer(x.data).view(-1, 1)

должно сработать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...