ValueError: repetition_penalty 和 no_repeat_ngram_size 不能同时设置,因为它们可能会冲突。
ValueError: repetition_penalty and no_repeat_ngram_size cannot be set simultaneously as they may conflict.
ID: huggingface/transformers-generation-config-repeat-penalty-conflict
版本兼容性
| 版本 | 状态 | 引入 | 弃用 | 备注 |
|---|---|---|---|---|
| transformers>=4.25.0 | active | — | — | — |
根因分析
在生成配置或 model.generate() 中同时设置了 repetition_penalty 和 no_repeat_ngram_size,但它们可能对 token 选择产生矛盾的效果。
English
Both repetition_penalty and no_repeat_ngram_size are set in generation config or passed to model.generate(), but they can produce contradictory effects on token selection.
官方文档
https://huggingface.co/docs/transformers/en/main_classes/text_generation#transformers.GenerationConfig解决方案
-
Remove one of the parameters: use only `repetition_penalty=1.2` (typical range 1.0-2.0) to discourage repetition, or `no_repeat_ngram_size=3` to block n-gram repeats. Example: `model.generate(inputs, repetition_penalty=1.2)` or `model.generate(inputs, no_repeat_ngram_size=3)`
-
If you need both effects, implement a custom repetition penalty that combines both strategies manually in a logits processor, then pass it via `model.generate(logits_processor=[...])`.
-
Check the generation config before calling: `if hasattr(model.generation_config, 'repetition_penalty') and model.generation_config.repetition_penalty is not None: model.generation_config.no_repeat_ngram_size = None`
无效尝试
常见但无效的做法:
-
60% 失败
Setting no_repeat_ngram_size=0 is valid but still triggers the conflict check; setting repetition_penalty=0.0 is invalid (must be >=1.0) and raises a different error.
-
50% 失败
The error is raised before generation; silent catch will cause the generation to proceed with default values, potentially producing unwanted repetition.
-
70% 失败
The GenerationConfig itself raises this error during validation, so it will fail before any generation occurs.