欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenAI?Function?Calling特性示例詳解

 更新時(shí)間:2023年07月09日 10:40:11   作者:莫爾索隨筆  
這篇文章主要為大家介紹了OpenAI?Function?Calling特性作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

Function Calling使用

OpenAI 在gpt-3.5-turbo-0613 和 gpt-4-0613兩個(gè)模型的chat completion api中增加了一個(gè)叫 Function Calling 的新功能,本篇文章對(duì)其功能進(jìn)行探究,并分析其作用。

我認(rèn)為這是一種比Plugin更優(yōu)雅的方式,給開發(fā)者提供了更多的自由度,一方面識(shí)別出何時(shí)需要調(diào)用函數(shù)來對(duì)輸出格式化,一方面設(shè)定具體的格式化數(shù)據(jù)有助于接入后續(xù)業(yè)務(wù)邏輯。達(dá)到盡可能保證(注意這里,是根據(jù)你的函數(shù)描述最大可能保證,不能100%)LLM輸出可控的基礎(chǔ)上,來增強(qiáng)自己業(yè)務(wù)的目的。

show me code

下面以記賬應(yīng)用為例,告訴AI:“今天喝奶茶花了6元”,正常思路來說,交互流程應(yīng)該是這樣的:

  • 用戶輸入prompt
  • AI進(jìn)行語義分析
  • 返回結(jié)構(gòu)化的數(shù)據(jù)(每個(gè)子項(xiàng)是什么,花費(fèi)是多少)
  • 拿到數(shù)據(jù)進(jìn)行下一步操作

借助Function Calling,微調(diào)后的模型可以檢測(cè)何時(shí)應(yīng)該調(diào)用函數(shù)并使用符合函數(shù)簽名的 JSON 進(jìn)行響應(yīng),下面看代碼例子??

import openai
import json
from enum import Enum
class BaseTool(Enum):
    Bookkeeping = "record_price"
    RecordingTask = "record_task"
def record_price(category, price):
    print(category, price)
    # 記賬應(yīng)用 API
    print("記賬成功!")
def funtion_call_conversation():
    response = openai.ChatCompletion.create(
    model="gpt-3.5-turbo-0613",
    messages=[
      {"role": "user", "content": "今天喝奶茶花了6元"},
    ],
    temperature=0,
    functions=[
      {
        "name": BaseTool.Bookkeeping.value,
        "description": "bookkeeping assistant",
        "parameters": {
          "type": "object",
          "properties": {
            "category": {
              "type": "string",
              "description": "類目",
            },
            "price": {"type": "string", "description": "金額"},
          },
          "required": ["category", "price"],
        },
      }
    ],
    function_call="auto",
    )
    message = response["choices"][0]["message"]
    if(message.get("function_call")):
        function_name = message["function_call"]["name"]
        if function_name == BaseTool.Bookkeeping.value:
            arguments = json.loads(message["function_call"]["arguments"])
            record_price(arguments.get('category'), arguments.get('price'))

接口調(diào)用說明

  • name字段表示要調(diào)用的函數(shù)名,description表示函數(shù)描述,paramters是一個(gè)符合JSON Schema格式的對(duì)象,用來描述這個(gè)函數(shù)的入?yún)⑿畔ⅲㄗ?LLM 讀得懂的工具函數(shù)說明)

record_price是用來給Function Calling調(diào)用的函數(shù),這個(gè)函數(shù)接收兩個(gè)必填的參數(shù),category類目(string類型),price金額(string類型)

functions=[
{
  "name": BaseTool.Bookkeeping.value,
  "description": "bookkeeping assistant",
  "parameters": {
    "type": "object",
    "properties": {
      "category": {"type": "string","description": "類目"},
      "price": {"type": "string", "description": "金額"},
    },
    "required": ["category", "price"],
  },
}
],

LLM分析結(jié)果

LLM 分析后命中了函數(shù)簽名描述,就會(huì)返回給我們 function_call 這個(gè)字段以及函數(shù)簽名中我們預(yù)定義的相關(guān)信息:

{
  "role": "assistant",
  "content": null,
  "function_call": {
    "name": "record_price",
    "arguments": "{\n  \"category\": \"\u5976\u8336\",\n  \"price\": \"6\u5143\"\n}"
  }
}
  • category返回給我們了類目是奶茶
  • price識(shí)別出了金額是6元

接下來拿到參數(shù),調(diào)用 record_price 進(jìn)行記賬的操作即可;如果沒有命中函數(shù)簽名描述,就不會(huì)返回function_call字段,也就不需要進(jìn)行任何操作:

if(message.get("function_call")):
        function_name = message["function_call"]["name"]
        if function_name == BaseTool.Bookkeeping.value:
            arguments = json.loads(message["function_call"]["arguments"])
            record_price(arguments.get('category'), arguments.get('price'))

按照這種思路,可以擴(kuò)展自己的外部工具,比如發(fā)郵件,記錄待辦清單,讓LLM變成私人管家。

AI記賬應(yīng)用設(shè)想

LLM 加持的記賬應(yīng)用設(shè)想,不需要打開記賬軟件寫類目記金額??:

  • 直接對(duì)照Siri說“今天喝奶茶花了6元”
  • 然后利用STT,轉(zhuǎn)換為文本
  • 利用上述程序提取類目和金額,調(diào)用記賬API,記錄成功

存在問題

  • 函數(shù)描述是會(huì)被計(jì)入token的(果然魔法都是有成本的??
  • 潛在的風(fēng)險(xiǎn):分析不準(zhǔn)確,出現(xiàn)無法命中函數(shù)簽名描述的情況

參考

以上就是OpenAI Function Calling特性作用詳解的詳細(xì)內(nèi)容,更多關(guān)于OpenAI Function Calling的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Django如何配置mysql數(shù)據(jù)庫

    Django如何配置mysql數(shù)據(jù)庫

    這篇文章主要為大家詳細(xì)介紹了Django配置mysql數(shù)據(jù)庫的詳細(xì)步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 詳解Django中的unittest及應(yīng)用

    詳解Django中的unittest及應(yīng)用

    unittest是python的一個(gè)單元測(cè)試框架,它是用于對(duì)一個(gè)確定結(jié)果和預(yù)測(cè)結(jié)果的一種判斷,這篇文章主要介紹了Django中的unittest及應(yīng)用,需要的朋友可以參考下
    2021-11-11
  • python中的3種定義類方法

    python中的3種定義類方法

    這篇文章主要給大家分享得是 python中的3種定義類方法,分別是普通方法、類方法(@classmethod)以及類方法(@classmethod),想了解方法具體實(shí)現(xiàn)的小伙伴可以參考下面文章內(nèi)容哦,希望對(duì)你有所幫助
    2021-11-11
  • PyQt5 多窗口連接實(shí)例

    PyQt5 多窗口連接實(shí)例

    今天小編就為大家分享一篇PyQt5 多窗口連接實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python 文本文件內(nèi)容批量抽取實(shí)例

    Python 文本文件內(nèi)容批量抽取實(shí)例

    今天小編就為大家分享一篇Python 文本文件內(nèi)容批量抽取實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Django中使用CORS實(shí)現(xiàn)跨域請(qǐng)求過程解析

    Django中使用CORS實(shí)現(xiàn)跨域請(qǐng)求過程解析

    這篇文章主要介紹了Django中使用CORS實(shí)現(xiàn)跨域請(qǐng)求過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • pandas dataframe添加表格框線輸出的方法

    pandas dataframe添加表格框線輸出的方法

    今天小編就為大家分享一篇pandas dataframe添加表格框線輸出的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • pip安裝時(shí)ReadTimeoutError的解決方法

    pip安裝時(shí)ReadTimeoutError的解決方法

    今天小編就為大家分享一篇pip安裝時(shí)ReadTimeoutError的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • python魔法方法-屬性轉(zhuǎn)換和類的表示詳解

    python魔法方法-屬性轉(zhuǎn)換和類的表示詳解

    下面小編就為大家?guī)硪黄猵ython魔法方法-屬性轉(zhuǎn)換和類的表示詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • 在windows系統(tǒng)中實(shí)現(xiàn)python3安裝lxml

    在windows系統(tǒng)中實(shí)現(xiàn)python3安裝lxml

    本文主要給大家簡(jiǎn)單介紹了下在windows以及l(fā)inux系統(tǒng)中使用Python安裝LXML模塊的教程,非常簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下
    2016-03-03

最新評(píng)論