Funcion Calling介绍
函数调用允许您将模型如gpt-4o与外部工具和系统连接起来。这对于许多事情都很有用,比如为AI助手赋能,或者在你的应用程序与模型之间建立深度集成。
如果您了解或者使用过Semantic Kernel可能会发现除了OpenAI支持Function Calling的模型之外,自动函数调用好像并不好用,国产大模型几乎都不能使用,由于想解决这个问题,在GitHub上找到了一个大佬的方法。
GitHub地址:https://github.com/Jenscaasen/UniversalLLMFunctionCaller
大佬是通过提示工程与Semantic Kernel中调用本地函数的原理来做的,我看了大佬的代码,将提示词改为了中文,可能会更适用于国产大模型。
之前写了一篇文章:如何让其他模型也能在SemanticKernel中调用本地函数介绍了这个方法。
但是当时自己并没有开源项目,感兴趣的朋友,没有办法快速地上手体验,只能自己重新来一遍,现在已将这部分内容集成到我的开源项目SimpleRAG中,感兴趣的朋友只需填入自己的API Key即可快速体验,也可以方便地查看代码了。
GitHub地址:https://github.com/Ming-jiayou/SimpleRAG
一种通用的Function Calling方法
在开始介绍之前,先看一下效果:
data:image/s3,"s3://crabby-images/8004e/8004ebd650fcd82de8f281fa1f50e863bdf411af" alt=""
对比一下不使用FunctionCalling的效果:
data:image/s3,"s3://crabby-images/9283d/9283d55d16d54c75153ad70ddbebe7f5834fdecf" alt=""
再来一个示例:
data:image/s3,"s3://crabby-images/d92f4/d92f49aa79fc018c2f451515b73e91c690a77cfb" alt=""
对比不使用Function Calling的效果:
data:image/s3,"s3://crabby-images/091de/091debbaaa6d0c71041195aeccb64948e5c20fbb" alt=""
具体代码可在GitHub中查看,这里重点介绍一下实现的过程。
这里以Qwen2-7B-Instruct为例。
首先创建一个Kernel:
data:image/s3,"s3://crabby-images/2dab4/2dab4e6bb1a26d45b8ab215e15722f9edaf06971" alt=""
在Kernel中导入插件:
data:image/s3,"s3://crabby-images/3ca57/3ca571826c29f3e5307bd37195f0ad3867a7fde3" alt=""
以上只是用于测试的模拟函数。
只需这样写即可:
data:image/s3,"s3://crabby-images/76f0c/76f0c166b2ee6e5bfef4a56727e0751e36a1dd8d" alt=""
现在探究一下里面的过程。
首先将插件转化为文本:
data:image/s3,"s3://crabby-images/2e815/2e81557b92cc2b902fd355324fb12b883ec95c7c" alt=""
data:image/s3,"s3://crabby-images/2b85b/2b85bfde63032aad0cc210ddde1d5e97be7e59f8" alt=""
在对话历史中加入示例:
data:image/s3,"s3://crabby-images/abe0a/abe0a9ab235ac67b4162cf49865f6f12cc08898e" alt=""
data:image/s3,"s3://crabby-images/932aa/932aa3c408cd879780e83d356ffa7a927ba52661" alt=""
在对话历史中加入一个指令:
data:image/s3,"s3://crabby-images/63488/6348818661d64299c5fab10fb7a93bb4ea2d44e8" alt=""
data:image/s3,"s3://crabby-images/d094a/d094ae729c1545262156ffeece37c82026f20e42" alt=""
将所有可用的函数嵌入到这个Prompt中了,如下所示:
data:image/s3,"s3://crabby-images/bdd6d/bdd6dd509529375c7c5bdab49df8b34ffc3238e2" alt=""
将指令加入到对话历史中了,如下所示:
data:image/s3,"s3://crabby-images/46151/4615100537899d3cb1a96fb97abbdc021bf777b3" alt=""
让LLM根据任务选择应该先调用哪个函数或者不用调用函数:
data:image/s3,"s3://crabby-images/751f2/751f22e8c9a396f6c08a0771ce4c6f9d52259933" alt=""
LLM返回完成这个任务需要调用的函数:
data:image/s3,"s3://crabby-images/e72dd/e72dde9b00de6c0553efc4136b3dbf81b190bd0d" alt=""
验证这个函数:
data:image/s3,"s3://crabby-images/bc252/bc25232b339bcf5c1ca6fe19a2ef500df5f2b3a7" alt=""
调用插件中的函数:
data:image/s3,"s3://crabby-images/296d8/296d88baf3dd1cbd282f3306903192d6d47f44c5" alt=""
data:image/s3,"s3://crabby-images/62085/620855b86c3562536abbfa002dfff7eecb324cf8" alt=""
data:image/s3,"s3://crabby-images/34a9b/34a9b7e32e48ebb622131bf9d4075be7eb8d65c8" alt=""
第一个函数返回的结果:
data:image/s3,"s3://crabby-images/0b810/0b810e5b8730a706c1bd0ba07d38c100ba65f890" alt=""
再向LLM发送请求,现在该调用哪个函数,LLM的返回如下所示:
data:image/s3,"s3://crabby-images/1a797/1a79719c73d056ccf2634ad3457ff775261818fd" alt=""
同样执行插件中的第二个函数:
data:image/s3,"s3://crabby-images/fac56/fac566ef6716a21616d1f7205f28360cd209498f" alt=""
第二个函数的返回:
data:image/s3,"s3://crabby-images/de7cd/de7cd83cf3761561855911f20d4e277b866774f4" alt=""
然后再向LLM发送请求:
data:image/s3,"s3://crabby-images/2e853/2e85333a85cfdc1629fede364623ea79b03ffead" alt=""
调用的函数名为Finished,表示流程已完成,可以跳出来了,如下所示:
data:image/s3,"s3://crabby-images/7eac7/7eac72f100178e1c3e6eeb284bb31bfbd098e676" alt=""
获得了最后的信息:
data:image/s3,"s3://crabby-images/4f332/4f332999c3b0f226af118999e56c356d91cf8d8d" alt=""
结果如下所示:
data:image/s3,"s3://crabby-images/95e52/95e52e5a6acde990f2906ffeb0c7e96ca7a75693" alt=""
以上就是这个方法的大概流程,具体实现可以看GitHub开源的代码。
经过测试这种方法可用的LLM
平台 | 可用模型 |
---|---|
硅基流动 | Llama-3.1-405/70/8B、Llama-3-70/8B-Instruct、DeepSeek-V2-Chat、deepseek-llm-67b-chat、Qwen2-72/57/7/1.5B-Instruct、Qwen2-57B-A14B-Instruct、Qwen1.5-110/32/14B-Chat、Qwen2-Math-72B-Instruct、Yi-1.5-34/9/6B-Chat-16K、internlm2_5-20/7b-chat |
讯飞星火 | Spark Lite、Spark Pro-128K、Spark Max、Spark4.0 Ultra |
零一万物 | yi-large、yi-medium、yi-spark、yi-large-rag、yi-large-fc、yi-large-turbo |
月之暗面 | moonshot-v1-8k、moonshot-v1-32k、moonshot-v1-128k |
智谱AI | glm-4-0520、glm-4、glm-4-air、glm-4-airx、glm-4-flash、glm-4v、glm-3-turbo |
DeepSeek | deepseek-chat、deepseek-coder |
阶跃星辰 | step-1-8k、step-1-32k、step-1-128k、step-2-16k-nightly、step-1-flash |
Minimax | abab6.5s-chat、abab5.5-chat |
阿里云百炼 | qwen-max、qwen2-math-72b-instruct、qwen-max-0428、qwen2-72b-instruct、qwen2-57b-a14b-instruct、qwen2-7b-instruct |
以上不一定完备,还有一些模型没测,欢迎大家继续补充。