购物网站app推广方案,天津建设工程新希望,凡科网站建设价格,济南高端建站前言
相比于传统纯文本的问答方式#xff0c;Function Calling 允许我们以更结构化、更可控的方式从大模型中获取精准数据#xff0c;为智能系统提供更强的上下文感知能力。
无论你是初学者#xff0c;还是有一定开发经验的技术爱好者#xff0c;这篇教程都将用清晰的逻辑…前言相比于传统纯文本的问答方式Function Calling 允许我们以更结构化、更可控的方式从大模型中获取精准数据为智能系统提供更强的上下文感知能力。无论你是初学者还是有一定开发经验的技术爱好者这篇教程都将用清晰的逻辑、丰富的实例帮助你快速掌握这项关键能力。基础知识什么是Function CallingFunction Calling 是 OpenAI 模型的一项高级能力允许模型不直接生成回答而是返回一个函数调用请求包含函数名与参数由开发者决定是否执行执行后再将结果反馈回模型以继续对话流程。这种设计的优势在于增强可控性我们可以检查模型的函数调用意图避免错误调用。提升灵活性可以加入校验机制、格式转换等操作。支持结构化输入输出便于和已有系统对接如数据库、API等。Function Calling 通常和 Pydantic、LangChain 等配套使用能够以更易维护的方式快速构建复杂的交互逻辑。那下面就让我们开始实战看看其作用吧实战Part1文本标注Tagging我们从一个简单的文本标注任务开始给定一段文本判断其情感正面/负面/中性以及语言如英文en、中文zh等。1.定义数据模型在这一步我们借助 Pydantic 创建一个用于情感与语言标注的数据结构并用 LangChain 提供的工具将其转换为大模型可识别的 function 调用格式。这样模型便能“知道”有哪些字段需要填写。from pydantic import BaseModel, Fieldclass Tagging(BaseModel): sentiment: str Field(description文本的情感倾向取值为 pos正面、neg负面或 neutral中性) language: str Field(description文本所用语言ISO 639-1 语言代码)转换为函数结构后大模型将会返回一个 JSON 格式的结构化调用请求而不是直接输出文本from langchain_core.utils.function_calling import convert_to_openai_functionconvert_to_openai_function(Tagging)2.构建对话链条我们使用 LangChain 的ChatPromptTemplate构造提示词模板同时绑定模型并明确指定调用的函数。这样可以保证模型不产生歧义而是直接触发我们定义好的函数结构。在使用前我们可以需要先通过pip install -U langchain langchain-openai安装一下openai的配套库。from langchain.prompts import ChatPromptTemplatefrom langchain_openai import ChatOpenAImodel ChatOpenAI( modelqwen-turbo, base_urlhttps://dashscope.aliyuncs.com/compatible-mode/v1, api_keyapi_key# 请替换成你的 API key)prompt ChatPromptTemplate.from_messages([ (system, 请仔细思考并按照要求对文本进行标注), (user, {input})])model_with_functions model.bind( functions[convert_to_openai_function(Tagging)], function_call{name: Tagging})tagging_chain prompt | model_with_functions3.调用与解析结果一切就绪后我们调用该链条并传入待标注的文本。模型会根据定义好的函数结构返回带有 sentiment 和 language 字段的结果print(tagging_chain.invoke({input: I love langchain}))输出结果如下content additional_kwargs{function_call: {arguments: {sentiment: pos, language: en}, name: Tagging}} response_metadata{token_usage: {completion_tokens: 18, prompt_tokens: 241, total_tokens: 259, completion_tokens_details: None}, model_name: qwen-turbo, system_fingerprint: None, finish_reason: stop, logprobs: None} idrun-6f20d16d-94a0-4a58-89ce-a95a3c8ed7cb-0可以看到其Function Call里面的arguments识别出来的是积极pos的情绪并且也写出对应的语言英文en。为了进一步规范输出我们还可以追加一个解析器使得输出内容更清爽from langchain.output_parsers.openai_functions import JsonOutputFunctionsParsertagging_chain prompt | model_with_functions | JsonOutputFunctionsParser()print(tagging_chain.invoke({input: I love langchain}))这样模型就只会选择出Function Call部分的内容输出结果如下{sentiment: pos, language: en}实战Part2信息抽取Extraction接下来我们尝试处理稍微复杂一点的结构化信息抽取任务“Joe is 30, his mom is Martha” —— 从中提取出人物姓名与年龄。1.定义嵌套结构本次任务需要抽取多个人物信息因此我们将构建一个嵌套的结构体外层是包含多个Person的Information内层是每个人的name和可选的age字段。from typing import List, Optionalfrom pydantic import BaseModel, Fieldclass Person(BaseModel): name: str Field(description人物姓名) age: Optional[int] Field(description人物年龄可缺失)class Information(BaseModel): people: List[Person] Field(description人物信息列表)这一步是关键Pydantic 允许我们通过这种嵌套结构清晰表达所需数据的层级关系。2.注册为Function并绑定模型有了数据结构后我们仍需将其注册为函数形式供大模型调用并指定函数名称info_fn convert_to_openai_function(Information)extraction_model model.bind(functions[info_fn], function_call{name: Information})这样模型收到输入后就会依据我们预设的结构返回 people 字段对应的所有人物信息。3.构造Prompt并执行链条我们设置提示词指导模型在抽取信息时不进行猜测只输出明确表达的信息prompt ChatPromptTemplate.from_messages([ (system, 提取文本中所有人物姓名和年龄), (user, {input})])extraction_chain prompt | extraction_model | JsonOutputFunctionsParser()执行调用print(extraction_chain.invoke({input: Joe is 30, his mom is Martha}))输出结构如下{people: [{name: Joe, age: 30}, {name: Martha, age: None}]}可以看到大模型成功提取出了两个人的信息一个是Joe对应是30岁另一个是Martha没有年龄信息。假如我们只想要对应的人物信息而不需要people的话我们也可以使用JsonKeyOutputFunctionsParser(key_namepeople)获取更简洁的列表格式结果。from langchain.output_parsers.openai_functions import JsonKeyOutputFunctionsParserextraction_chain prompt | extraction_model | JsonKeyOutputFunctionsParser(key_namepeople)print(extraction_chain.invoke({input: Joe is 30, his mom is Martha}))输出结构如下[{name: Joe, age: 30}, {name: Martha, age: None}]这样我们就成功完成提取任务信息的任务啦完整代码如下所示from langchain_openai import ChatOpenAIfrom langchain_core.utils.function_calling import convert_to_openai_functionfrom pydantic import BaseModel, Fieldfrom langchain.prompts import ChatPromptTemplatefrom langchain.output_parsers.openai_functions import JsonOutputFunctionsParserfrom typing import List, Optionalfrom langchain.output_parsers.openai_functions import JsonKeyOutputFunctionsParsermodel ChatOpenAI( modelqwen-turbo, base_urlhttps://dashscope.aliyuncs.com/compatible-mode/v1, api_keyapi_key# 你的 API key)# class Tagging(BaseModel):# sentiment: str Field(description文本的情感倾向取值为 pos正面、neg负面或 neutral中性)# language: str Field(description文本所用语言ISO 639-1 语言代码) # convert_to_openai_function(Tagging)# prompt ChatPromptTemplate.from_messages([# (system, 请仔细思考并按照要求对文本进行标注),# (user, {input})# ])# model_with_functions model.bind(# functions[convert_to_openai_function(Tagging)],# function_call{name: Tagging}# )# tagging_chain prompt | model_with_functions# print(tagging_chain.invoke({input: I love langchain}))# tagging_chain prompt | model_with_functions | JsonOutputFunctionsParser()# print(tagging_chain.invoke({input: I love langchain}))# --------------------------class Person(BaseModel): name: str Field(description人物姓名) age: Optional[int] Field(description人物年龄可缺失)class Information(BaseModel): people: List[Person] Field(description人物信息列表)info_fn convert_to_openai_function(Information)extraction_model model.bind(functions[info_fn], function_call{name: Information})prompt ChatPromptTemplate.from_messages([ (system, 提取文本中所有人物姓名和年龄), (user, {input})])extraction_chain prompt | extraction_model | JsonOutputFunctionsParser()print(extraction_chain.invoke({input: Joe is 30, his mom is Martha}))extraction_chain prompt | extraction_model | JsonKeyOutputFunctionsParser(key_namepeople)print(extraction_chain.invoke({input: Joe is 30, his mom is Martha}))总结通过这篇教程我们基于LangChain与OpenAI的Function Calling机制完成了两个典型任务文本标签识别Tagging嵌套结构信息抽取Extraction你不仅学会了如何设计Pydantic模型、注册为函数、绑定模型、执行调用还掌握了如何使用解析器解析函数结果极大提升了对大模型调用逻辑的理解。下节预告网页抽取与多段文本分析我们将进一步挑战真实内容处理任务如何从整篇网页中提取结构化信息如何批量提取被引用的论文标题与作者面对数千字长文如何用 LangChain 分段、并行处理如何学习大模型 AI 由于新岗位的生产效率要优于被取代岗位的生产效率所以实际上整个社会的生产效率是提升的。但是具体到个人只能说是“最先掌握AI的人将会比较晚掌握AI的人有竞争优势”。这句话放在计算机、互联网、移动互联网的开局时期都是一样的道理。我在一线互联网企业工作十余年里指导过不少同行后辈。帮助很多人得到了学习和成长。我意识到有很多经验和知识值得分享给大家也可以通过我们的能力和经验解答大家在人工智能学习中的很多困惑所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限很多互联网行业朋友无法获得正确的资料得到学习提升故此将并将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。第一阶段10天初阶应用该阶段让大家对大模型 AI有一个最前沿的认识对大模型 AI 的理解超过 95% 的人可以在相关讨论时发表高级、不跟风、又接地气的见解别人只会和 AI 聊天而你能调教 AI并能用代码将大模型和业务衔接。大模型 AI 能干什么大模型是怎样获得「智能」的用好 AI 的核心心法大模型应用业务架构大模型应用技术架构代码示例向 GPT-3.5 灌入新知识提示工程的意义和核心思想Prompt 典型构成指令调优方法论思维链和思维树Prompt 攻击和防范…第二阶段30天高阶应用该阶段我们正式进入大模型 AI 进阶实战学习学会构造私有知识库扩展 AI 的能力。快速开发一个完整的基于 agent 对话机器人。掌握功能最强的大模型开发框架抓住最新的技术进展适合 Python 和 JavaScript 程序员。为什么要做 RAG搭建一个简单的 ChatPDF检索的基础概念什么是向量表示Embeddings向量数据库与向量检索基于向量检索的 RAG搭建 RAG 系统的扩展知识混合检索与 RAG-Fusion 简介向量模型本地部署…第三阶段30天模型训练恭喜你如果学到这里你基本可以找到一份大模型 AI相关的工作自己也能训练 GPT 了通过微调训练自己的垂直大模型能独立训练开源多模态大模型掌握更多技术方案。到此为止大概2个月的时间。你已经成为了一名“AI小子”。那么你还想往下探索吗为什么要做 RAG什么是模型什么是模型训练求解器 损失函数简介小实验2手写一个简单的神经网络并训练它什么是训练/预训练/微调/轻量化微调Transformer结构简介轻量化微调实验数据集的构建…第四阶段20天商业闭环对全球大模型从性能、吞吐量、成本等方面有一定的认知可以在云端和本地等多种环境下部署大模型找到适合自己的项目/创业方向做一名被 AI 武装的产品经理。硬件选型带你了解全球大模型使用国产大模型服务搭建 OpenAI 代理热身基于阿里云 PAI 部署 Stable Diffusion在本地计算机运行大模型大模型的私有化部署基于 vLLM 部署大模型案例如何优雅地在阿里云私有部署开源大模型部署一套开源 LLM 项目内容安全互联网信息服务算法备案…学习是一个过程只要学习就会有挑战。天道酬勤你越努力就会成为越优秀的自己。如果你能在15天内完成所有的任务那你堪称天才。然而如果你能完成 60-70% 的内容你就已经开始具备成为一名大模型 AI 的正确特征了。这份完整版的大模型 AI 学习资料已经上传CSDN朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】