ChatGLM2-6B/cli_demo.py

63 lines
2.3 KiB
Python
Raw Normal View History

2023-06-25 15:32:49 +08:00
import os
import platform
import signal
from transformers import AutoTokenizer, AutoModel
import readline
from utils import load_model_on_gpus
2023-06-25 15:32:49 +08:00
tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True)
2023-06-26 13:32:14 +08:00
model = AutoModel.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True).cuda()
# 多显卡支持使用下面三行代替上面两行将num_gpus改为你实际的显卡数量
# model_path = "THUDM/chatglm2-6b"
# tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True)
# model = load_model_on_gpus(model_path, num_gpus=2)
2023-06-25 15:32:49 +08:00
model = model.eval()
os_name = platform.system()
clear_command = 'cls' if os_name == 'Windows' else 'clear'
stop_stream = False
def build_prompt(history):
2023-06-26 10:17:03 +08:00
prompt = "欢迎使用 ChatGLM2-6B 模型输入内容即可进行对话clear 清空对话历史stop 终止程序"
2023-06-25 15:32:49 +08:00
for query, response in history:
prompt += f"\n\n用户:{query}"
2023-06-26 10:17:03 +08:00
prompt += f"\n\nChatGLM2-6B{response}"
2023-06-25 15:32:49 +08:00
return prompt
def signal_handler(signal, frame):
global stop_stream
stop_stream = True
def main():
past_key_values, history = None, []
global stop_stream
print("欢迎使用 ChatGLM2-6B 模型输入内容即可进行对话clear 清空对话历史stop 终止程序")
while True:
query = input("\n用户:")
if query.strip() == "stop":
break
if query.strip() == "clear":
past_key_values, history = None, []
os.system(clear_command)
print("欢迎使用 ChatGLM2-6B 模型输入内容即可进行对话clear 清空对话历史stop 终止程序")
continue
2023-06-27 09:51:05 +08:00
print("\nChatGLM", end="")
current_length = 0
2023-06-25 15:32:49 +08:00
for response, history, past_key_values in model.stream_chat(tokenizer, query, history=history,
past_key_values=past_key_values,
return_past_key_values=True):
if stop_stream:
stop_stream = False
break
else:
2023-06-27 09:51:05 +08:00
print(response[current_length:], end="", flush=True)
current_length = len(response)
print("")
2023-06-25 15:32:49 +08:00
if __name__ == "__main__":
main()