面向开发者的LLM入门课程-端到端实现问答系统: 端到端实现问答系统 在我们的探索之旅中,我们将实现一个完整的问答系统,一种能理解并回应人类语言的人工智能。在这个……
哈喽!伙伴们,我是小智,你们的AI向导。欢迎来到每日的AI学习时间。今天,我们将一起深入AI的奇妙世界,探索“面向开发者的LLM入门课程-端到端实现问答系统”,并学会本篇文章中所讲的全部知识点。还是那句话“不必远征未知,只需唤醒你的潜能!”跟着小智的步伐,我们终将学有所成,学以致用,并发现自身的更多可能性。话不多说,现在就让我们开始这场激发潜能的AI学习之旅吧。
面向开发者的LLM入门课程-端到端实现问答系统:
端到端实现问答系统
在我们的探索之旅中,我们将实现一个完整的问答系统,一种能理解并回应人类语言的人工智能。在这个过程中,我们将使用 OpenAI 的相关API并引用相关函数,来帮助我们快速搭建一个高效且精准的模型。然而,我们需要注意到,在中文的理解和处理方面,由于模型的特性,我们可能会偶尔遇到不理想的结果。在这种情况下,你可以多尝试几次,或者进行深入的研究,以找到更稳定的方法。
让我们先从一个函数开始,它的名称是 process_user_message_ch ,该函数主要负责处理用户输入的信息。这个函数接收三个参数,用户的输入、所有的历史信息,以及一个表示是否需要调试的标志。在函数的内部,我们首先使用 OpenAI 的 Moderation API 来检查用户输入的合规性。如果输入被标记为不合规,我们将返回一个信息,告知用户请求不合规。在调试模式下,我们将打印出当前的进度。
接下来,我们利用 utils_zh.find_category_and_product_only 函数(详细请见附录代码)抽取出用户输入中的商品和对应的目录。然后,我们将抽取的信息转化为一个列表。
在获取到商品列表后,我们将查询这些商品的具体信息。之后,我们生成一个系统消息,设定一些约束,以确保我们的回应符合期望的标准。我们将生成的消息和历史信息一起送入get_completion_from_messages 函数,得到模型的回应。之后,我们再次使用 Moderation API 检查模型的输出是否合规。如果输出不合规,我们将返回一个信息,告知无法提供该信息。
最后,我们让模型自我评估是否很好地回答了用户的问题。如果模型认为回答是满足要求的,我们则返回模型的回答;否则,我们会告知用户,他们将会被转接到人工客服进行进一步的帮助。
import openai
import utils_zh
from tool import get_completion_from_messages
”’
注意:限于模型对中文理解能力较弱,中文 Prompt 可能会随机出现不成功,可以多次运行;也非常欢迎同学
探究更稳定的中文 Prompt
”’
def process_user_message_ch(user_input, all_messages, debug=True):
“””
对用户信息进行预处理
参数:
user_input : 用户输入
all_messages : 历史信息
debug : 是否开启 DEBUG 模式,默认开启
“””
# 分隔符
delimiter = ““`”
# 第一步: 使用 OpenAI 的 Moderation API 检查用户输入是否合规或者是一个注入的 Prompt
response = openai.Moderation.create(input=user_input)
moderation_output = response[“results”][0]
# 经过 Moderation API 检查该输入不合规
if moderation_output[“flagged”]:
print(“第一步:输入被 Moderation 拒绝”)
return “抱歉,您的请求不合规”
# 如果开启了 DEBUG 模式,打印实时进度
if debug: print(“第一步:输入通过 Moderation 检查”)
# 第二步:抽取出商品和对应的目录,类似于之前课程中的方法,做了一个封装
category_and_product_response =
utils_zh.find_category_and_product_only(user_input,
utils_zh.get_products_and_category())
#print(category_and_product_response)
# 将抽取出来的字符串转化为列表
category_and_product_list =
utils_zh.read_string_to_list(category_and_product_response)
#print(category_and_product_list)
if debug: print(“第二步:抽取出商品列表”)
# 第三步:查找商品对应信息
product_information =
utils_zh.generate_output_string(category_and_product_list)
if debug: print(“第三步:查找抽取出的商品信息”)
# 第四步:根据信息生成回答
system_message = f”””
您是一家大型电子商店的客户服务助理。
请以友好和乐于助人的语气回答问题,并提供简洁明了的答案。
请确保向用户提出相关的后续问题。
“””
# 插入 message
messages = [
{‘role’: ‘system’, ‘content’: system_message},
{‘role’: ‘user’, ‘content’: f”{delimiter}{user_input}{delimiter}”},
{‘role’: ‘assistant’, ‘content’: f”相关商品信息:n{product_information}”}
]
# 获取 GPT3.5 的回答
# 通过附加 all_messages 实现多轮对话
final_response = get_completion_from_messages(all_messages + messages)
if debug:print(“第四步:生成用户回答”)
# 将该轮信息加入到历史信息中
all_messages = all_messages + messages[1:]
# 第五步:基于 Moderation API 检查输出是否合规
response = openai.Moderation.create(input=final_response)
moderation_output = response[“results”][0]
# 输出不合规
if moderation_output[“flagged”]:
if debug: print(“第五步:输出被 Moderation 拒绝”)
return “抱歉,我们不能提供该信息”
if debug: print(“第五步:输出经过 Moderation 检查”)
# 第六步:模型检查是否很好地回答了用户问题
user_message = f”””
用户信息: {delimiter}{user_input}{delimiter}
代理回复: {delimiter}{final_response}{delimiter}
回复是否足够回答问题
如果足够,回答 Y
如果不足够,回答 N
仅回答上述字母即可
“””
# print(final_response)
messages = [
{‘role’: ‘system’, ‘content’: system_message},
{‘role’: ‘user’, ‘content’: user_message}
]
# 要求模型评估回答
evaluation_response = get_completion_from_messages(messages)
# print(evaluation_response)
if debug: print(“第六步:模型评估该回答”)
# 第七步:如果评估为 Y,输出回答;如果评估为 N,反馈将由人工修正答案
if “Y” in evaluation_response: # 使用 in 来避免模型可能生成 Yes
if debug: print(“第七步:模型赞同了该回答.”)
return final_response, all_messages
else:
if debug: print(“第七步:模型不赞成该回答.”)
neg_str = “很抱歉,我无法提供您所需的信息。我将为您转接到一位人工客服代表以获取进一步
帮助。”
return neg_str, all_messages
user_input = “请告诉我关于 smartx pro phone 和 the fotosnap camera 的信息。另外,请告诉
我关于你们的tvs的情况。”
response,_ = process_user_message_ch(user_input,[])
print(response)
第一步:输入通过 Moderation 检查
第二步:抽取出商品列表
第三步:查找抽取出的商品信息
第四步:生成用户回答
第五步:输出经过 Moderation 检查
第六步:模型评估该回答
第七步:模型赞同了该回答.
关于SmartX ProPhone和FotoSnap相机的信息如下:
SmartX ProPhone:
– 品牌:SmartX
– 型号:SX-PP10
– 屏幕尺寸:6.1英寸
– 存储容量:128GB
– 相机:12MP双摄像头
– 网络:支持5G
– 保修:1年
– 价格:899.99美元
FotoSnap相机系列:
1. FotoSnap DSLR相机:
– 品牌:FotoSnap
– 型号:FS-DSLR200
– 传感器:24.2MP
– 视频:1080p
– 屏幕:3英寸LCD
– 可更换镜头
– 保修:1年
– 价格:599.99美元
2. FotoSnap无反相机:
– 品牌:FotoSnap
– 型号:FS-ML100
– 传感器:20.1MP
– 视频:4K
– 屏幕:3英寸触摸屏
– 可更换镜头
– 保修:1年
– 价格:799.99美元
3. FotoSnap即时相机:
– 品牌:FotoSnap
– 型号:FS-IC10
– 即时打印
– 内置闪光灯
– 自拍镜
– 电池供电
– 保修:1年
– 价格:69.99美元
关于我们的电视情况如下:
1. CineView 4K电视:
– 品牌:CineView
– 型号:CV-4K55
– 屏幕尺寸:55英寸
– 分辨率:4K
– HDR支持
– 智能电视功能
– 保修:2年
– 价格:599.99美元
2. CineView 8K电视:
– 品牌:
嘿,伙伴们,今天我们的AI探索之旅已经圆满结束。关于“面向开发者的LLM入门课程-端到端实现问答系统”的内容已经分享给大家了。感谢你们的陪伴,希望这次旅程让你对AI能够更了解、更喜欢。谨记,精准提问是解锁AI潜能的钥匙哦!如果有小伙伴想要了解学习更多的AI知识,请关注我们的官网“AI智研社”,保证让你收获满满呦!
还没有评论呢,快来抢沙发~