RoboWaiter/robowaiter/llm_client/tool_api.py

85 lines
2.7 KiB
Python
Raw Normal View History

import json
import openai
from colorama import init, Fore
from loguru import logger
from tool_register import get_tools, dispatch_tool
import requests
import json
import urllib3
2023-11-14 15:26:02 +08:00
init(autoreset=True)
########################################
2023-11-14 15:26:02 +08:00
# 该文件实现了与大模型的通信以及工具调用
########################################
# 忽略https的安全性警告
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
base_url = "https://45.125.46.134:25344" # 本地部署的地址,或者使用你访问模型的API地址
def get_response(**kwargs):
data = kwargs
response = requests.post(f"{base_url}/v1/chat/completions", json=data, stream=data["stream"], verify=False)
decoded_line = response.json()
return decoded_line
functions = get_tools()
def run_conversation(query: str, stream=False, functions=None, max_retry=5):
params = dict(model="chatglm3", messages=[{"role": "user", "content": query}], stream=stream)
if functions:
params["functions"] = functions
response = get_response(**params)
for _ in range(max_retry):
if response["choices"][0]["message"].get("function_call"):
function_call = response["choices"][0]["message"]["function_call"]
logger.info(f"Function Call Response: {function_call}")
function_args = json.loads(function_call["arguments"])
tool_response = dispatch_tool(function_call["name"], function_args)
logger.info(f"Tool Call Response: {tool_response}")
params["messages"].append(response["choices"][0]["message"])
params["messages"].append(
{
"role": "function",
"name": function_call["name"],
"content": tool_response, # 调用函数返回结果
}
)
else:
reply = response["choices"][0]["message"]["content"]
logger.info(f"Final Reply: \n{reply}")
return
response = get_response(**params)
if __name__ == "__main__":
# chat_messages = [
# {
# "role": "system",
# "content": "You are ChatGLM3, a large language model trained by Zhipu.AI. Follow the user's instructions carefully. Respond using markdown.",
# },
# {
# "role": "user",
# "content": "你好给我讲一个故事大概100字"
# }
# ]
# create_chat_completion("chatglm3-6b", chat_messages, use_stream=False)
2023-11-14 15:26:02 +08:00
# query = "你是谁"
# run_conversation(query, stream=False)
#
# logger.info("\n=========== next conversation ===========")
2023-11-14 15:26:02 +08:00
query = "洗手间在哪儿"
run_conversation(query, functions=functions, stream=False)