|
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) |