1

在使用 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
}

4

1 回答 1

1
  1. 如果内存问题仍然存在,您可以选择 DistillGPT2,因为它减少了 33% 的网络参数(前向传播速度也快了一倍)。特别是对于像 6GB VRAM 这样的小型 GPU 内存,它可能是您问题的解决方案/替代方案。
  2. 同时,这取决于您如何预处理数据。实际上,该模型能够“接收”最大长度的N令牌(例如512/768),具体取决于您选择的模型。我最近训练了一个命名实体识别模型,该模型具有最大长度的768标记。但是,当我在 PyTorch 中手动将填充标记的维度设置DataLoader()为一个大数字时,我也得到了 OOM 内存(甚至是on 3090 24GB VRAM)。当我将令牌的维度减小到小得多(512而不是 768例如)时,训练开始起作用,并且我没有遇到任何内存不足的问题。

TLDR:无论网络的最大容量如何,减少预处理阶段的令牌数量也可以帮助解决您的记忆问题。

于 2022-01-06T13:26:50.983 回答