У меня есть обученная модель, использующая LSTM.Модель обучается на GPU (в Google COLABORATORY).Я должен сохранить модель для вывода;который я буду запускать на CPU .После обучения я сохранил контрольную точку модели следующим образом:
torch.save({'model_state_dict': model.state_dict()},'lstmmodelgpu.tar')
И, для вывода, я загрузил модель как:
# model definition
vocab_size = len(vocab_to_int)+1
output_size = 1
embedding_dim = 300
hidden_dim = 256
n_layers = 2
model = SentimentLSTM(vocab_size, output_size, embedding_dim, hidden_dim, n_layers)
# loading model
device = torch.device('cpu')
checkpoint = torch.load('lstmmodelgpu.tar', map_location=device)
model.load_state_dict(checkpoint['model_state_dict'])
model.eval()
Но возникает следующая ошибка:
model.load_state_dict(checkpoint['model_state_dict'])
File "workspace/envs/envdeeplearning/lib/python3.5/site-packages/torch/nn/modules/module.py", line 719, in load_state_dict
self.__class__.__name__, "\n\t".join(error_msgs)))
RuntimeError: Error(s) in loading state_dict for SentimentLSTM:
Missing key(s) in state_dict: "embedding.weight".
Unexpected key(s) in state_dict: "encoder.weight".
Что я пропустил при сохранении контрольной точки?