主頁 >  其他 > 【OpenAI】ChatGPT函式呼叫(Function Calling)實踐

【OpenAI】ChatGPT函式呼叫(Function Calling)實踐

2023-07-07 08:04:48 其他

6月13日OpenAI在Chat Completions API中添加了新的函式呼叫(Function Calling)能力,幫助開發者通過API方式實作類似于ChatGPT插件的資料互動能力,

本文在作者上一篇文章《私有框架代碼生成實踐》的基礎上,依舊使用自然語言低代碼搭建場景作為案例,將嵌入向量搜索(Embedding)獲取私有知識庫的方式,替換為函式呼叫方式,以我們更熟悉的結構化資料結構、關系型資料庫的方式進行知識庫管理,同時函式呼叫能力的靈活性和可擴展性,也可以幫助用戶使用自然語言搭建更加復雜的頁面內容、進行更豐富的互動操作,

一、 什么是函式呼叫

函式呼叫(Function Calling)是OpenAI在6月13日發布的新能力,根據官方博客描述,函式呼叫能力可以讓模型輸出一個請求呼叫函式的訊息,其中包含所需呼叫的函式資訊、以及呼叫函式時所攜帶的引數資訊,這是一種將GPT能力與外部工具/API連接起來的新方式,

支持函式呼叫的新模型,可以根據用戶的輸入自行判斷何時需要呼叫哪些函式,并且可以根據目標函式的描述生成符合要求的請求引數,

開發人員可以使用函式呼叫能力,通過GPT實作:

  • 在進行自然語言交流時,通過呼叫外部工具回答問題(類似于ChatGPT插件);
  • 將自然語言轉換為呼叫API時使用的引數,或者查詢資料庫時使用的條件;
  • 從文本中提取結構化資料,等

二、 如何使用函式呼叫

函式呼叫能力可以通過聊天API(Chat Completion)使用,為了實作函式呼叫能力,OpenAI對聊天API進行了修改,增加了新的請求引數、回應型別以及訊息角色,應用開發者需要:

  1. 在請求引數中向聊天API傳遞資訊,描述應用所提供的可呼叫函式的資訊,
  2. 決議聊天API回應的訊息型別,若模型決定需要呼叫函式,則根據模型回傳的函式資訊和函式傳參呼叫函式,并獲得回傳結果,
  3. 將函式回傳的結果添加到訊息串列中,并再次呼叫聊天API,

1. 添加請求引數, 描述所支持的函式資訊

聊天API中新增了兩個請求體引數:

functions

當前應用可呼叫的函式的串列,函式資訊中包含了函式的名稱、自然語言描述、以及函式所支持傳入的引數資訊,

functions引數的格式如下:

openai.createChatCompletion({
  model: "gpt-3.5-turbo-0613",
  messages: [
    // ...
  ],
  functions: [
    {
      name: 'function_name',
      description: '該函式所具備能力的自然語言描述',
      parameters: {
        type: 'object',
        properties: {
          argument_name: {
            type: 'string',
            description: '該引數的自然語言描述'
          },
          // ...
        },
        required: ['argument_name']
      }
    },
    // ...
  ]
})

functions引數支持以陣列形式錄入多組函式資訊,其中:

  • name:函式名稱,后續模型會在需要呼叫函式時回傳此名稱,

  • description:函式功能描述,模型通過該描述理解函式能力,并判斷是否需要呼叫該函式,

  • parameters.properties:函式所需的引數,以物件的形式描述函式所需的引數,其中物件的key即為引數名,

    • type:引數型別,支持JSON Schema協議,
    • description:引數描述,
  • required:必填引數的引數名串列,

function_call

控制模型應該如何回應函式調換,支持幾種輸入:

  1. "none":模型不呼叫函式,直接回傳內容,沒有提供可呼叫函式時的默認值,
  2. "auto":模型根據用戶輸入自行決定是否呼叫函式以及呼叫哪個函式,提供可呼叫函式時的默認值,
  3. {"name": "function_name"}:強制模型呼叫指定的函式,

2. 識別回應引數, 描述需要呼叫的函式資訊

聊天API在回應內容的可選項(choices)中提供了兩個回應引數:

finish_reason

回應內容結束的原因,

可能的原因包括:

  • stop:已回傳完整訊息,
  • length:已達到令牌限制或由max_tokens引數設定的上限,
  • function_call:模型決定需要呼叫一個函式,
  • content_filter:內容觸發了攔截策略,忽略回傳內容,
  • null:API回應仍在執行,

其中,若回傳function_call則表示模型需要呼叫函式,此時message引數會額外回傳函式資訊以及函式引數資訊,

message.function_call

若回應內容結束的原因是模型需要呼叫函式,則message引數中會增加一個用于描述函式資訊的function_call引數,其格式如下:

  • name:函式名稱,
  • arguments:函式引數資訊,JSON字串格式,

3. 添加對話角色, 向訊息串列中添加函式回傳值

在函式執行完成后,可以將函式的回傳內容追加到訊息串列中,并攜帶完整的訊息串列再次請求聊天API,以獲得GPT的后續回應,

在訊息串列中,角色的可選值除了原有的系統system)、用戶user)、助理assistant)外,新增了函式function)型別,用來標識該訊息時函式呼叫的回傳內容,

注意:向訊息串列中追加函式呼叫回應訊息前,還需要首先將上一步模型回傳的訊息追加到訊息串列中,以保證訊息串列中的背景關系完整,

完整使用代碼

const { Configuration, OpenAIApi } = require("openai");
const openai = new OpenAIApi(new Configuration({ /** OpenAI 配置 */ }));

/** 系統角色資訊 **/
const systemPrompt: string = "系統角色prompt";

/** 支持函式資訊 **/
const functionsPrompt: unknow[] = [
  {
    name: 'function_name',
    description: '函式功能的自然語言描述',
    parameters: {
      type: 'object',
      properties: {
        argument_name: {
          type: 'string',
          description: '該引數的自然語言描述'
        },
        // ...
      }
    }
  },
  // ...
];

/** 支持函式邏輯 **/
const functionsCalls: { [name: string]: Function } = {
  function_name: (args: { argument_name: string }) => {
    const { argument_name } = args;
    // ...
    return '函式呼叫結果'
  },
  // ...
}

/** 開始聊天 **/
const chat = async (userPrompt: string) => {
  const messages: unknow[] = [
    { role: 'system', content: systemPrompt },
    { role: 'user', content: userPrompt }
  ];
  
  let maxCall = 6;
  while (maxCall--) {
    const responseData = https://www.cnblogs.com/Jcloud/p/await openai.createChatCompletion({
      model:"gpt-3.5-turbo-0613",
      messages,
      functions,
      function_call: maxCall === 0 ? 'none' : 'auto'
    }).then((response) => response.data.choices[0]);
  
    const message = responseData.message
    messages.push(message)

    const finishReason = responseData.finish_reason
    if (finishReason === 'function_call') {
      const functionName = message.function_call.name
      const functionCall = functionCalls[functionName]
      const functionArguments = JSON.parse(message.function_call.arguments)
      const functionResponse = await functionCall(functionArguments)
      messages.push({
        role: 'function',
        name: functionName,
        content: functionResponse
      })
    } else {
      return message.content
    }
  }
}

三、 低代碼自然語言搭建案例

在作者的上一篇文章中,使用嵌入向量搜索提供的“檢索-提問解決方案”進行低代碼私有協議的訪問,在本文中,將使用函式呼叫方式進行替代,

同時,基于函式呼叫的能力,也探索了一些更加復雜的頁面搭建能力和低代碼平臺功能,

1. 私有協議訪問

基于我們的低代碼平臺私有協議,在進行CMS型別頁面的搭建時,我們將協議的知識劃分為幾個層級,并分別提供函式供GPT按需呼叫,以實作私有協議的訪問,

系統描述資訊

const systemPropmpt = `使用CCMS協議撰寫頁面的配置資訊,

                       CCMS協議所支持的頁面型別包括:
                       - *form*:表單頁
                       - *table*:表格頁
                       - *detail*:詳情頁`;

函式資訊描述

const functionsPrompt = [
  {
    name: 'get_elements',
    description: '獲取CCMS協議在指定頁面型別下,所支持的元素型別,',
    parameters: {
      type: 'object',
      properties: {
        page: {
          type: 'array',
          description: '頁面型別',
          items: { type: 'string' }
        }
      }
    },
    required: ['page']
  },
  {
    name: 'get_features',
    description: '獲取CCMS協議在指定元素型別下,所支持的配置化特性,',
    parameters: {
      type: 'object',
      properties: {
        element: {
          type: 'array',
          description: '元素型別',
          items: { type: 'string' }
        }
      }
    },
    required: ['element']
  },
  {
    name: 'get_descriptions',
    description: '獲取CCMS協議下,指定頁面型別、元素型別以及配置化特性的詳細資訊,',
    parameters: {
      type: 'object',
      properties: {
        page: {
          type: 'array',
          description: '頁面型別',
          items: { type: 'string' }
        },
        element: {
          type: 'array',
          description: '元素型別',
          items: { type: 'string' }
        },
        feature: {
          type: 'array',
          description: '配置化特性',
          items: { type: 'string' }
        }
      }
    }
  }
]

備注:盡管GPT模型支持函式的回圈呼叫,但出于減少API呼叫頻次和節省Token消耗的目的,我們建議在查詢私有協議資訊的函式中,使用關鍵詞陣列的形式進行批量查詢,

函式內容

const functionsCalls = {
  get_elements: (args: { page: string[] }) => {
    const { page } = args;
    // 請自行實作資訊查詢,下列回傳內容僅為示例,
    return page.map((pageType) => {
      switch (pageType) {
        case 'form':
          return `# **form**表單頁所支持的元素型別包括:

                  - *form_text*:文本輸入框
                  - *form_number*: 數值輸入框`;
        default:
          return `# **${pageType}**沒有支持的元素,`
      }
    }).join("\n\n");
  },
  get_features: (args: { element: string[] }) => {
    const { element } = args
    // 請自行實作資訊查詢,下列回傳內容僅為示例,
    return element.map((elementKey) => {
      const [ pageType, elementType ] = elementKey.split('_');
      switch (pageType) {
        case 'form':
          switch (elementType) {
            case 'text':
              return `# **form_text**(文本輸入框)所支持的配置化特性包括:

                      - *form_text_maxLength*: 文本最大長度限制
                      - *form_text_minLength*: 文本最小長度限制
                      - *form_text_regExp*: 文本正則運算式校驗`
            default:
              return `# **${elementKey}**沒有支持的配置化特性,`
          }
        default:
          return `# **${elementKey}**沒有支持的配置化特性,`
      }
    }).join("\n\n");
  },
  get_descriptions: (args: { page: string[], element: string[], feature: string[] }) => {
    const {
      page = [],
      element = [],
      feature = []
    } = args
    // 請自行實作資訊查詢,下列回傳內容僅為示例,
    return [
      ...page.map((pageType) => `# **${pageType}**的詳細描述如下:...`),
      ...element.map((elementType) => `# **${elementType}**的詳細描述如下:...`),
      ...feature.map((featureType) => `# **${featureType}**的詳細描述如下:...`)
    ].join("\n\n")
  }
}

呼叫示例

一次完整呼叫的訊息串列:

為了便于閱讀,已經調整了訊息串列中訊息內容的縮進排版,并且將表示函式呼叫引數的JSON字串決議為物件形式,

[
  // 第一次請求聊天API
  { role: 'system', 
    content: `使用CCMS協議撰寫頁面的配置資訊,
              
              CCMS協議所支持的頁面型別包括:
              - *form*: 表單頁
              - *table*: 表格頁
              - *detail*: 詳情頁` },
  { role: 'user',
    content: '創建一個課程報名頁面' },
  { role: 'assistant',
    content: null,
    function_call: { name: 'get_elements',
                     arguments: { page: ["form"] } } },

  // 第二次請求聊天API
  { role: 'function',
    name: 'get_elements',
    content: `# **form**表單頁所支持的元素型別包括:

              - *form_text*:文本輸入框
              - *form_number*: 數值輸入框` },
  { role: 'assistant',
    content: null,
    function_call: { name: 'get_features',
                     arguments: { element: ["form_text", "form_number"] } } },

  // 第三次請求聊天API
  { role: 'function',
    name: 'get_features',
    content: `# **form_text**(文本輸入框)所支持的配置化特性包括:

              - *form_text_maxLength*: 文本最大長度限制
              - *form_text_minLength*: 文本最小長度限制
              - *form_text_regExp*: 文本正則運算式校驗
              
              # **form_number**沒有支持的配置化特性,` },
  { role: 'assistant',
    content: null,
    function_call: { name: 'get_descriptions',
                     arguments: { page: ["form"],
                                  element: ["form_text", "form_number"],
                                  feature: ["form_text_maxLength", "form_text_minLength", "form_text_regExp"] } } },

  // 第四次請求聊天API
  { role: 'function',
    name: 'get_descriptions',
    content: `# **form**的詳細描述如下:...
              
              # **form_text**的詳細描述如下:...
              
              # **form_number**的詳細描述如下:...
              
              # **form_text_maxLength**的詳細描述如下:...
              
              # **form_text_minLength**的詳細描述如下:...
              
              # **form_text_regExp**的詳細描述如下:...` },
  { role: 'assistant',
    content: '課程報名頁面的配置資訊如下:\n\n...' }
]

2. 頁面搭建能力擴展: 頁面背景關系跳轉場景

在進行低代碼頁面搭建時,有時會需要在頁面配置中加入一些背景關系資訊,

例如需要在頁面中添加一個按鈕,用戶點擊按鈕時跳轉至另一個頁面,此時我們可以通過一個函式,允許模型獲取相關的頁面串列,

關于按鈕、跳轉操作等協議內容可以通過上一章節中的方法獲取:

## button
 
按鈕,

支持的配置項包括:

- *label*:按鈕標簽
- *action*:操作型別,支持:
  - *none*:無操作
  - *redirect*:頁面重定向
- *redirectTo*:頁面標識

函式資訊描述

const functionsPrompt = [
  // ...
  {
    name: 'get_page_id',
    description: '查詢頁面標識串列,其中包含頁面標識(`id`)、頁面名稱(`name`)',
    parameters: {
      type: 'object',
      properties: {
        page: {
          type: 'string',
          description: '頁面'
        }
      }
    }
  }
]

函式內容

const functionsCalls = {
  // ...
  get_page_id: (args: {}) => {
    // 請自行實作資訊查詢,下列回傳內容僅為示例,
    return JSON.stringify([
      {
        id: 'page_list',
        name: '串列頁'
      },
      {
        id: 'page_create',
        name: '新增頁',
        description: '用于新增內容'
      },
      {
        id: 'page_preview',
        name: '預覽頁'
      }
    ])
  }
}

呼叫示例

一次完整呼叫的訊息串列:

為了便于閱讀,已經調整了訊息串列中訊息內容的縮進排版,并且將GPT回傳的配置資訊和表示函式呼叫引數的JSON字串決議為物件形式,

[
  // 已省略系統角色資訊以及私有協議訪問資訊,
  // ...
  { role: 'user',
    content: '添加一個預覽按鈕,點擊后跳轉至預覽頁,'
  },
  // ...
  { role: 'assistant',
    content: { type: "button",
               label: "預覽",
               action: "redirect",
               redirectTo: "preview" },
    function_call: { name: 'get_page_id',
                     arguments: { page: "preview" } } },
  { role: 'function',
    name: 'get_page_id',
    content: [ { id: "page_list", name: "串列頁" },
               { id: "page_create", name: "新增頁" },
               { id: "page_preview", name: "預覽頁"} ] },
  { role: 'assistant',
    content: { type: "button",
               label: "預覽",
               action: "redirect",
               redirectTo: "page_preview" }
]

3. 低代碼平臺能力擴展: 搭建視窗可視區域調整

在進行自然語言低代碼搭建時,我們希望讓搭建視窗的可視區域自動滾動到發生變化的區域,此時可以通過系統角色要求在進行頁面配置變動時呼叫頁面滾動方法,自動滾動至發生配置變化的元素位置,

系統描述資訊

在系統描述資訊中添加相關描述:

const systemPropmpt = `//...

                       每次對頁面內容進行調整時,需要滾動頁面至目標元素位置,
                       
                       CCMS頁面配置資訊為一個陣列,每個頁面元素為陣列中的一項,如:

                       ```json
                       [
                         {
                           "id": "input",
                           "type": "text",
                           "label": "文本輸入框"
                         }
                       ]
                       ```
                       
                       // ...
                       `;

函式資訊描述

const functionsPrompt = [
  // ...
  {
    name: 'scroll_to',
    description: '滾動頁面至指定元素位置',
    parameters: {
      type: 'object',
      properties: {
        element_id: {
          type: 'string',
          description: '指定元素ID'
        }
      }
    }
  }
]

函式內容

const functionsCalls = {
  // ...
  scroll_id: (args: { element_id: string }) => {
    const { element_id } = args
    // 自行實作頁面滾動邏輯
    return '滾動完成'
  }
}

四、 總結

OpenAI提供的函式呼叫功能為使用GPT能力的應用提供了更豐富的可能性,應用開發者可以通過函式呼叫功能,讓用戶通過自然語言互動,獲取實時資料、結構化資料,同時也可以與應用進行各類互動,本文中描述的幾個案例場景僅為拋磚引玉,歡迎大家多多討論,嘗試更多應用場景,

作者:京東零售 牛曉光

來源:京東云開發者社區

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/556709.html

標籤:其他

上一篇:天翼云邊緣安全加速平臺亮相2023亞太內容分發大會暨CDN峰會

下一篇:返回列表

標籤雲
其他(162152) Python(38266) JavaScript(25524) Java(18291) C(15238) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7288) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4613) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) HtmlCss(1989) .NET技术(1985) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1882) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 【OpenAI】ChatGPT函式呼叫(Function Calling)實踐

    OpenAI提供的函式呼叫功能為使用GPT能力的應用提供了更豐富的可能性。應用開發者可以通過函式呼叫功能,讓用戶通過自然語言互動,獲取實時資料、結構化資料,同時也可以與應用進行各類互動。本文中描述的幾個案例場景僅為拋磚引玉,歡迎大家多多討論,嘗試更多應用場景。 ......

    uj5u.com 2023-07-07 08:04:48 more
  • 天翼云邊緣安全加速平臺亮相2023亞太內容分發大會暨CDN峰會

    6月29日,第十二屆亞太內容分發大會暨CDN峰會在北京召開。大會聚集了行業領/袖、專家和學者,深度探討CDN的技術發展、應用與未來發展趨勢,會上還公布了2023邊緣加速創新企業榜單,中國電信天翼云成功上榜。此外,天翼云科技有限公司智能邊緣事業部產品專家羅崎文分享了天翼云一體化邊緣解決方案Access... ......

    uj5u.com 2023-07-07 08:04:31 more
  • 自適應辛普森法積分演算法推導

    引子 有時候我們需要計算一個函式的定積分,粗略上可以使用估算的方法。如圖所示,將原本的曲線粗略地看成一個梯形。這個方法叫梯形法則(Trapezoidal Rule)。也叫做一階牛頓-柯特斯閉型積分公式。 其中 所謂一階,指的就是n=1的情況。 最理想的情況就是把這個影像分割成 無數 個梯形,便可求出 ......

    uj5u.com 2023-07-07 08:03:57 more
  • 云計算在商業運營中的潛力

    云計算在業務運營中的潛力已成為改變游戲規則的創新

    利用云進行業務運營已成為一種范式轉換創新,可幫助企業提高效率和可擴展性。 通過使用云的可能性,公司可以改善溝通、降低成本并簡化流程。本文將探討云計算增強業務流程的各種方式。 ......

    uj5u.com 2023-07-07 08:03:42 more
  • JavaScript實作合并排序演算法詳解

    JavaScript實作歸并排序演算法詳解 說明 歸并排序(Merge Sort)演算法,也叫合并排序,是創建在歸并操作上的一種有效的排序演算法。演算法是采用分治法(Divide and Conquer)的一個非常典型的應用,且各層分治遞回可以同時進行。歸并排序思路簡單,速度僅次于快速排序,為穩定排序演算法, ......

    uj5u.com 2023-07-07 08:03:38 more
  • 極限科技受邀參加 2023 可信資料庫發展大會并入選 “中國資料庫

    7 月 4-5 日,由中國資訊通信研究院(以下簡稱"中國信通院")、中國通信標準化協會主辦,中國通信標準化協會大資料技術標準推進委員會承辦,InfoQ 聯合主辦的 "2023 可信資料庫發展大會" 主論壇在北京國際會議中心隆重召開。 中國通信標準化協會副理事長兼秘書長代曉慧以視頻方式致辭,中國資訊通 ......

    uj5u.com 2023-07-07 08:03:07 more
  • 【工程報告】面試01號工程報告

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-07-07 08:02:49 more
  • ConvertToRinex批處理工具

    Convert To Rinex軟體是有天寶公司(Trimble)所開發的GNSS資料解碼程式,?于將天GNSS接識訓的原始資料?件(DAT、T00、T01、RT17、RT27或.cap)轉化成RINEX格式。ConverToRinex314版本可轉換為Rinex v2.10、v2.11、v3.02 ......

    uj5u.com 2023-07-07 08:02:34 more
  • 使用Stable Diffusion生成藝術二維碼

    使用Stable Diffusion生成藝術二維碼是一個有趣且富有創意的程序,它將藝術與技術相結合,為我們提供了一種全新的方式來表達和傳遞資訊 ......

    uj5u.com 2023-07-07 08:02:13 more
  • 在idea/webstorm等terminal運行命令報錯:Command rejected by the

    在idea/webstorm等編譯器terminal視窗運行命令報錯:Command rejected by the operating system沒有權限,Command rejected by the operating system ......

    uj5u.com 2023-07-07 07:55:13 more