如何为transformer gpt 2保存检查点以继续训练?

How to save checkpoints for thie transformer gpt2 to continue training?

我正在重新训练 GPT2 语言模型,并且正在关注此博客:

https://towardsdatascience.com/train-gpt-2-in-your-own-language-fc6ad4d60171

在这里,他们已经在 GPT2 上训练了一个网络,我正在尝试重新创建一个网络。但是,我的数据集太大(250Mb),所以我想继续间隔训练。换句话说,我想检查模型训练。如果有任何帮助,或者一段代码我可以实施到检查点并继续训练,那对我来说会很有帮助。谢谢。

training_args = TrainingArguments(
    output_dir=model_checkpoint,
    # other hyper-params
)

trainer = Trainer(
    model=model,
    args=training_args,
    train_dataset=train_set,
    eval_dataset=dev_set,
    tokenizer=tokenizer
)

trainer.train()
# Save the model to model_dir
trainer.save_model()

def prepare_model(tokenizer, model_name_path):
    model = AutoModelForCausalLM.from_pretrained(model_name_path)
    model.resize_token_embeddings(len(tokenizer))
    return model

# Assume tokenizer is defined, You can simply pass the saved model directory path.
model = prepare_model(tokenizer, model_checkpoint)