2023-11-14 12:10:23 +08:00
|
|
|
|
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 12:10:23 +08:00
|
|
|
|
########################################
|
2023-11-14 15:26:02 +08:00
|
|
|
|
# 该文件实现了与大模型的通信以及工具调用
|
2023-11-14 12:10:23 +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 12:10:23 +08:00
|
|
|
|
|
2023-11-14 15:26:02 +08:00
|
|
|
|
query = "洗手间在哪儿"
|
2023-11-14 12:10:23 +08:00
|
|
|
|
run_conversation(query, functions=functions, stream=False)
|