在使用 HuggingFace Transformers 库微调 GPT-2 模型时,我再次出现 CUDA 内存不足错误,尽管我的 GPU 容量为 6 GB,但我认为这应该足以进行微调,但似乎无法解决它在文本上。错误如下:
File "GPT\lib\site-packages\torch\nn\modules\module.py", line 1102, in _call_impl
return forward_call(*input, **kwargs)
File "GPT\lib\site-packages\transformers\modeling_utils.py", line 1763, in forward
x = torch.addmm(self.bias, x.view(-1, x.size(-1)), self.weight)
RuntimeError: CUDA out of memory. Tried to allocate 144.00 MiB (GPU 0; 6.00 GiB total capacity; 4.28 GiB already allocated; 24.50 MiB free; 4.33 GiB reserved in total by PyTorch) If reserved memory is >> allocated memory try setting max_split_size_mb to avoid fragmentation. See documentation for Memory Management and PYTORCH_CUDA_ALLOC_CONF
我已经将批量大小设置为 2,并减少了训练示例但没有成功。我还尝试将代码迁移到 Colab,在那里 12GB RAM 很快就被消耗掉了。我的例子很长,有 2.400 个字符,但它们应该被模型自动截断。我的(德语)示例如下所示:
Er geht in fremde Wohnungen, balgt sich mit Freund und Feind, ist
zudringlich zu unsern Sämereien und Kirschen. Wenn die Gesellschaft nicht groß
ist, lasse ich sie gelten und streue ihnen sogar Getreide. Sollten sie hier
aber doch zu viel werden, so hilft die Windbüchse, und sie werden in den
Meierhof hinabgescheucht. Als einen bösen Feind zeigte sich der Rotschwanz. Er
flog zu dem Bienenhause und schnappte die Tierchen weg. Da half nichts, als ihn
ohne Gnade mit der Windbüchse zu töten.
Ich wollte
Ihnen mein Wort halten, liebe Mama, aber die Versuchung war zu groß. Da bin ich
eines Abends in den Keller gegangen und hab' aus allen Fässern den Spund
herausgeklopft. Bis auf den letzten Tropfen ist das Gift ausgeronnen aus den
Fässern. Der Schade war groß, aber der Teufel war aus dem Haus. «
Andor lachte. »Mama, das Geschrei hätten Sie hören sollen! Als ob der
Weltuntergang gekommen wäre. Er bedauerte beinahe seine
Schroffheit. Nun, nachlaufen wird er ihnen nicht, die werden schon selber
kommen. Aber bewachen wird er seine Kolonie bei Tag und bei Nacht lassen
müssen. Hol' der Teufel diesen Mercy. Muß der gerade in Högyész ein Kastell
haben. Wenn einer von den Schwarzwäldern dahin kommt und ihn verklagt.
可能是数据格式有问题吗?如果有人对如何解决这个问题有提示,那将是非常受欢迎的。
编辑:谢谢Timbus Calin的回答,我在评论中描述了如何将block_size
标志添加到 config.json 解决问题。以下是整个配置供参考:
{
"model_name_or_path": "dbmdz/german-gpt2",
"train_file": "Fine-Tuning Dataset/train.txt",
"validation_file": "Fine-Tuning Dataset/test.txt",
"output_dir": "Models",
"overwrite_output_dir": true,
"per_device_eval_batch_size": 8,
"per_device_train_batch_size": 8,
"block_size": 100,
"task_type": "text-generation",
"do_train": true,
"do_eval": true
}