AI大模型学习笔记-- Function Calling

AI大模型学习笔记-- Function Calling

前面的文章已经多次提到Function Calling,可见Function Calling在AI大模型搭建的重要性。

我们已经知道通过Function calling可以让用户能够高效的使用外部工具、外部API进行交互,来实现一些基础大模型无法完成的推理。

那么,今天我们一起来学习Function Calling的概念,以及在构建私有专属大模型中的应用。

什么是Function Calling

Function Calling是OpenAI在2023年6月13日发布在Chat Completions API中添加的新能力,帮助开发者通过API方式实现类似于ChatGPT插件的数据交互能力。

Chat Completion模型是一种基于人工智能的自然语言处理技术,可以根据用户的输入生成相应的回答。

而Function Calling允许用户在使用模型处理特定问题时,定制并调用专有的函数,这些函数可以是专门为处理特定任务(如数据分析、图像处理等)而设计的代码块,从而让Chat Completion模型可以调用外部函数获取信息再针对输出进行格式化。

这个描述可能有点难以理解,简单来说,就是OpenAI允许我们通过调用外部数据的方式来增强大模型,那么调用外部数据的方式就是这个Function Calling,翻译过来叫函数调用。

附上Function Calling官方文档地址:https://platform.openai.com/docs/guides/function-calling

Function Calling有什么用

通过使用函数调用能力,可以满足当前大模型无法解决的部分问题,包括:

  • • 在进行自然语言交互时,可以通过调用外部工具回答问题(类似于 ChatGPT 插件)。

  • • 将自然语言转换为调用API时使用的参数,或者查询数据库时使用的条件。

  • • 从文本中提取结构化数据。

如何使用Function Calling

为了实现Function Calling能力,OpenAI对Chat Completion进行了修改,增加了新的请求参数、响应类型以及消息角色,应用开发者需要:

  • • 在请求参数中向Chat Completion传递信息,描述应用所提供的可调用函数的信息。

  • • 解析Chat Completion响应的消息类型,若模型决定需要调用函数,则根据模型返回的函数信息和函数传参调用函数,并获得返回结果。

  • • 将函数返回的结果添加到消息列表中,并再次调用Chat Completion。

定义外部调用的函数

大模型具有执行多个函数的能力,并且允许并行执行和解释函数调用返回的结果,因此我们需要先定义好一个或多个函数。

定义tools

请求参数tools为当前应用可调用的函数的列表(以前的命名为functions)。函数信息中包含了函数的名称、自然语言描述、以及函数所支持传入的参数信息。

tools参数的格式如下:

tools = [  
    {  
      name: '函数名',  
      description: '该函数所具备能力的自然语言描述',  
      parameters: {  
        type: 'object',  
        properties: {  
          argument_name: {  
            type: 'string',  
            description: '该参数的自然语言描述'  
          },  
          // ...  
        },  
        required: ['argument_name']  
      }  
    },  
    // ...  
]

tools参数支持以数组形式录入多组函数信息,我们可以定义一个或多个tools,由大模型决定调用谁,其中:

  • • name:函数名称。后续模型会在需要调用函数时返回此名称。

  • • description:函数功能描述。模型通过该描述理解函数能力,并判断是否需要调用该函数。

  • • parameters.properties:函数所需的参数。以对象的形式描述函数所需的参数,其中对象的 key 即为参数名。

  • • type:参数类型。支持 JSON Schema 协议。

  • • description:参数描述。

  • • required:必填参数的参数名列表。

在环境中注册函数

我们需要在环境中注册这些函数,才能让大模型知道并能在需要的时候调用。

response = client.chat.completions.create(  
    model="gpt-3.5-turbo",  
    messages=messages,  
    tools=tools,  
    tool_choice="auto",  # auto is default, but we'll be explicit  
)

tool_choice: "auto"是默认的,由模型自行决定是否调用函数,也可以设置tool_choice: "none"来强制模型生成面向用户的消息。

tool_calls

response_message = response.choices[0].message  
tool_calls = response_message.tool_calls  

如果使用函数,则输出将在响应中包含 “finish_reason”: “tool_calls” ,以及具有tool_calls函数名称和生成的函数参数的对象。

function_to_call

前面的文章我们说过,大模型不会直接执行函数,也并不是大模型让我们干什么我们就得干什么,另外也需要规避无限调用的可能,我们可以把大模型返回的tool_calls当作一个建议,需要进行判断,再决定是否调用。

if (tool_calls is not None):  
    for tool_call in tool_calls:  
        if (逻辑判断):  
            function_name = tool_call.function.name  
            function_to_call = available_functions[function_name]  
            function_args = json.loads(tool_call.function.arguments)  
            function_response = function_to_call(  
                ...  
            )  
            # 把函数调用结果加入到对话历史中  
            messages.append(  
                {  
                    "tool_call_id": tool_call.id,  
                    "role": "tool",  
                    "name": function_name,  
                    "content": function_response,  
                }  
            )  
            # 再次请求大模型  
            second_response = client.chat.completions.create(  
                model="gpt-3.5-turbo",  
                messages=messages,  
            )

需要注意的地方

在函数执行完成后,可以将函数的返回内容追加到消息列表中,并携带完整的消息列表再次请求Chat Completion API,以获得GPT的后续响应。

在消息列表中,角色的可选值除了原有的系统(system)、用户(user)、助理(assistant)外,新增了函数(function)类型,用来标识该消息时函数调用的返回内容。

向消息列表中追加函数调用响应消息前,还需要首先将上一步模型返回的消息追加到消息列表中,以保证消息列表中的上下文完整。

人工智能大模型越来越火了,离全民大模型的时代不远了,大模型应用场景非常多,不管是做主业还是副业或者别的都行,技多不压身,我这里有一份全套的大模型学习资料,希望给那些想学习大模型的小伙伴们一点帮助!

👉AI大模型学习路线汇总👈

大模型学习路线图,整体分为7个大的阶段:(全套教程文末领取哈)

第一阶段: 从大模型系统设计入手,讲解大模型的主要方法;

第二阶段: 在通过大模型提示词工程从Prompts角度入手更好发挥模型的作用;

第三阶段: 大模型平台应用开发借助阿里云PAI平台构建电商领域虚拟试衣系统;

第四阶段: 大模型知识库应用开发以LangChain框架为例,构建物流行业咨询智能问答系统;

第五阶段: 大模型微调开发借助以大健康、新零售、新媒体领域构建适合当前领域大模型;

第六阶段: 以SD多模态大模型为主,搭建了文生图小程序案例;

第七阶段: 以大模型平台应用与开发为主,通过星火大模型,文心大模型等成熟大模型构建大模型行业应用。

👉大模型实战案例👈

光学理论是没用的,要学会跟着一起做,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

在这里插入图片描述

👉大模型视频和PDF合集👈

观看零基础学习书籍和视频,看书籍和视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
在这里插入图片描述
在这里插入图片描述

👉学会后的收获:👈

• 基于大模型全栈工程实现(前端、后端、产品经理、设计、数据分析等),通过这门课可获得不同能力;

• 能够利用大模型解决相关实际项目需求: 大数据时代,越来越多的企业和机构需要处理海量数据,利用大模型技术可以更好地处理这些数据,提高数据分析和决策的准确性。因此,掌握大模型应用开发技能,可以让程序员更好地应对实际项目需求;

• 基于大模型和企业数据AI应用开发,实现大模型理论、掌握GPU算力、硬件、LangChain开发框架和项目实战技能, 学会Fine-tuning垂直训练大模型(数据准备、数据蒸馏、大模型部署)一站式掌握;

• 能够完成时下热门大模型垂直领域模型训练能力,提高程序员的编码能力: 大模型应用开发需要掌握机器学习算法、深度学习框架等技术,这些技术的掌握可以提高程序员的编码能力和分析能力,让程序员更加熟练地编写高质量的代码。

👉获取方式:

😝有需要的小伙伴,可以保存图片到wx扫描二v码免费领取【保证100%免费】🆓

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT猫仔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值