Spaces:
Running
Running
import time | |
import os | |
from toolbox import update_ui, get_conf, update_ui_lastest_msg | |
from toolbox import check_packages, report_exception, have_any_recent_upload_image_files | |
model_name = '智谱AI大模型' | |
zhipuai_default_model = 'glm-4' | |
def validate_key(): | |
ZHIPUAI_API_KEY = get_conf("ZHIPUAI_API_KEY") | |
if ZHIPUAI_API_KEY == '': return False | |
return True | |
def make_media_input(inputs, image_paths): | |
for image_path in image_paths: | |
inputs = inputs + f'<br/><br/><div align="center"><img src="file={os.path.abspath(image_path)}"></div>' | |
return inputs | |
def predict_no_ui_long_connection(inputs, llm_kwargs, history=[], sys_prompt="", observe_window=[], console_slience=False): | |
""" | |
⭐多线程方法 | |
函数的说明请见 request_llms/bridge_all.py | |
""" | |
watch_dog_patience = 5 | |
response = "" | |
if llm_kwargs["llm_model"] == "zhipuai": | |
llm_kwargs["llm_model"] = zhipuai_default_model | |
if validate_key() is False: | |
raise RuntimeError('请配置ZHIPUAI_API_KEY') | |
# 开始接收回复 | |
from .com_zhipuglm import ZhipuChatInit | |
zhipu_bro_init = ZhipuChatInit() | |
for chunk, response in zhipu_bro_init.generate_chat(inputs, llm_kwargs, history, sys_prompt): | |
if len(observe_window) >= 1: | |
observe_window[0] = response | |
if len(observe_window) >= 2: | |
if (time.time() - observe_window[1]) > watch_dog_patience: | |
raise RuntimeError("程序终止。") | |
return response | |
def predict(inputs, llm_kwargs, plugin_kwargs, chatbot, history=[], system_prompt='', stream=True, additional_fn=None): | |
""" | |
⭐单线程方法 | |
函数的说明请见 request_llms/bridge_all.py | |
""" | |
chatbot.append([inputs, ""]) | |
yield from update_ui(chatbot=chatbot, history=history) | |
# 尝试导入依赖,如果缺少依赖,则给出安装建议 | |
try: | |
check_packages(["zhipuai"]) | |
except: | |
yield from update_ui_lastest_msg(f"导入软件依赖失败。使用该模型需要额外依赖,安装方法```pip install --upgrade zhipuai```。", | |
chatbot=chatbot, history=history, delay=0) | |
return | |
if validate_key() is False: | |
yield from update_ui_lastest_msg(lastmsg="[Local Message] 请配置ZHIPUAI_API_KEY", chatbot=chatbot, history=history, delay=0) | |
return | |
if additional_fn is not None: | |
from core_functional import handle_core_functionality | |
inputs, history = handle_core_functionality(additional_fn, inputs, history, chatbot) | |
chatbot[-1] = [inputs, ""] | |
yield from update_ui(chatbot=chatbot, history=history) | |
if llm_kwargs["llm_model"] == "zhipuai": | |
llm_kwargs["llm_model"] = zhipuai_default_model | |
if llm_kwargs["llm_model"] in ["glm-4v"]: | |
have_recent_file, image_paths = have_any_recent_upload_image_files(chatbot) | |
if not have_recent_file: | |
chatbot.append((inputs, "没有检测到任何近期上传的图像文件,请上传jpg格式的图片,此外,请注意拓展名需要小写")) | |
yield from update_ui(chatbot=chatbot, history=history, msg="等待图片") # 刷新界面 | |
return | |
if have_recent_file: | |
inputs = make_media_input(inputs, image_paths) | |
chatbot[-1] = [inputs, ""] | |
yield from update_ui(chatbot=chatbot, history=history) | |
# 开始接收回复 | |
from .com_zhipuglm import ZhipuChatInit | |
zhipu_bro_init = ZhipuChatInit() | |
for chunk, response in zhipu_bro_init.generate_chat(inputs, llm_kwargs, history, system_prompt): | |
chatbot[-1] = [inputs, response] | |
yield from update_ui(chatbot=chatbot, history=history) | |
history.extend([inputs, response]) | |
yield from update_ui(chatbot=chatbot, history=history) |