* Zhipu sdk update 适配最新的智谱SDK,支持GLM4v (#1502) * 适配 google gemini 优化为从用户input中提取文件 * 适配最新的智谱SDK、支持glm-4v * requirements.txt fix * pending history check --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * Update "生成多种Mermaid图表" plugin: Separate out the file reading function (#1520) * Update crazy_functional.py with new functionality deal with PDF * Update crazy_functional.py and Mermaid.py for plugin_kwargs * Update crazy_functional.py with new chart type: mind map * Update SELECT_PROMPT and i_say_show_user messages * Update ArgsReminder message in get_crazy_functions() function * Update with read md file and update PROMPTS * Return the PROMPTS as the test found that the initial version worked best * Update Mermaid chart generation function * version 3.71 * 解决issues #1510 * Remove unnecessary text from sys_prompt in 解析历史输入 function * Remove sys_prompt message in 解析历史输入 function * Update bridge_all.py: supports gpt-4-turbo-preview (#1517) * Update bridge_all.py: supports gpt-4-turbo-preview supports gpt-4-turbo-preview * Update bridge_all.py --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * Update config.py: supports gpt-4-turbo-preview (#1516) * Update config.py: supports gpt-4-turbo-preview supports gpt-4-turbo-preview * Update config.py --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * Refactor 解析历史输入 function to handle file input * Update Mermaid chart generation functionality * rename files and functions --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> Co-authored-by: hongyi-zhao <hongyi.zhao@gmail.com> Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * 接入mathpix ocr功能 (#1468) * Update Latex输出PDF结果.py 借助mathpix实现了PDF翻译中文并重新编译PDF * Update config.py add mathpix appid & appkey * Add 'PDF翻译中文并重新编译PDF' feature to plugins. --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * fix zhipuai * check picture * remove glm-4 due to bug * 修改config * 检查MATHPIX_APPID * Remove unnecessary code and update function_plugins dictionary * capture non-standard token overflow * bug fix #1524 * change mermaid style * 支持mermaid 滚动放大缩小重置,鼠标滚动和拖拽 (#1530) * 支持mermaid 滚动放大缩小重置,鼠标滚动和拖拽 * 微调未果 先stage一下 * update --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * ver 3.72 * change live2d * save the status of ``clear btn` in cookie * 前端选择保持 * js ui bug fix * reset btn bug fix * update live2d tips * fix missing get_token_num method * fix live2d toggle switch * fix persistent custom btn with cookie * fix zhipuai feedback with core functionality * Refactor button update and clean up functions --------- Co-authored-by: XIao <46100050+Kilig947@users.noreply.github.com> Co-authored-by: Menghuan1918 <menghuan2003@outlook.com> Co-authored-by: hongyi-zhao <hongyi.zhao@gmail.com> Co-authored-by: Hao Ma <893017927@qq.com> Co-authored-by: zeyuan huang <599012428@qq.com>
93 lines
3.7 KiB
Python
93 lines
3.7 KiB
Python
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) |