Search code examples
python-3.xpytorchartificial-intelligence

I get this error using PyTorch: RuntimeError: gather_out_cpu(): Expected dtype int64 for index


I'm trying to make an AI with PyTorch, but I get this error:

RuntimeError: gather_out_cpu(): Expected dtype int64 for index

And this is my function:

def learn(self, batch_state, batch_next_state, batch_reward, batch_action):
    outputs = self.model(batch_state).gather(1, batch_action.unsqueeze(1)).squeeze(1)
    next_outputs = self.model(batch_next_state).detach().max(1)[0]
    target = self.gamma * next_outputs + batch_reward
    td_loss = F.smooth_l1_loss(outputs, target)
    self.optimizer.zero_grad()
    td_loss.backward(retain_variables = True)
    self.optimizer.step()

Solution

  • You need to change the data type of your batch_action tensor before passing it to torch.gather.

    def learn(...):
        batch_action = batch_action.type(torch.int64) 
        outputs = ...
        ...
    
    # or
    outputs = self.model(batch_state).gather(1, batch_action.type(torch.int64).unsqueeze(1)).squeeze(1)