[THUDM/ChatGLM-6B][BUG/Help] 随着对话轮数增加,有什么方法可以防止/减少ChatGLM的显存增加吗?

2024-05-10 211 views
3
Current Behavior

“进行 2 至 3 轮对话后,8-bit 量化下 GPU 显存占用约为 10GB,4-bit 量化下仅需 6GB 占用。随着对话轮数的增多,对应消耗显存也随之增长”

我使用ChatGLM实现一个角色扮演的应用,也遇到了类似问题。每次对话后,ChatGLM显存使用增加几百到1、2G。

  • 请问为什么会这样呢?是因为模型内部把上轮对话的历史保存了起来?
  • 有什么方法可以防止或者减少显存的增加吗?我可以使用prompt带入上下文历史,不需要模型内部保存上下文

感谢!

Steps To Reproduce

正常和ChatGLM对话即可

Environment
- OS: Ubuntu 20.04
- Python: 3.10
- Transformers: 4.26.1
- PyTorch: 1.12
- CUDA Support: True

回答

8

你好 我也是这个问题 请问解决没有

5

要是并发有10个人同时提问,此不是每次ChatGLM显存使用增加到10、20G。

5

限制历史的对话输入就行。

9

限制历史的对话输入就行。

问题是我没有设置history,glm是默认增加历史对话记录吗,那么如何只限制单轮对话,不储存对话历史

4

限制历史的对话输入就行。

问题是我没有设置history,glm是默认增加历史对话记录吗,那么如何只限制单轮对话,不储存对话历史

你去看底层的api,有history的使用。

0

chatglm_llm.py def generatorAnswer(self, prompt: str, history: List[List[str]] = [], streaming: bool = False): history = [] ##强制制空列表 if streaming:

3

mark

2

api.py中有torch_gc