Qwen的FunctionCall模版整理

Qwen Function call实现及长对话优化问题

Qwen的chattemplate一看太复杂了,似乎最开始有tools的说明,assisatant会输出tool call并加入对话,以下给出Qwen官方的一个demo和自己的注释说明

基本Function call的实现划分为4步骤

  1. 定义函数,并使用Json格式存储函数说明
  2. 定义对话Prompt模板,将tools和message送给LLM处理
  3. 解析LLM的<tool_call></tool_call>并执行函数得到返回结果<tool_response></tool_response>
  4. 函数返回结果送给LLM继续处理query
{%- if tools %} #是否存在工具类,在对话最开始提供
    {
  
  {- '<|im_start|>system\n' }}
    {%- if messages[0]['role'] == 'system' %}
        {
  
  {- messages[0]['content'] }}
    {%- else %}
        {
  
  {- 'You are Qwen, created by Alibaba Cloud. You are a helpful assistant.' }}
    {%- endif %}
    {
  
  {- "\n\n# Tools\n\nYou may call one or more functions to assist with the user query.\n\nYou are provided with function signatures within <tools></tools> XML tags:\n<tools>" }}
    {%- for tool in tools %}
        {
  
  {- "\n" }}
        {
  
  {- tool | tojson }}
    {%- endfor %}
    {
  
  {- "\n</tools>\n\nFor each function call, return a json object with function name and arguments within <tool_call></tool_call> XML tags:\n<tool_call>\n{\"name\": <function-name>, \"arguments\": <args-json-object>}\n</tool_call><|im_end|>\n" }}
{%- else %} #正常对话第一步走这个流程
    {%- if messages[0]['role'] == 'system' %}
        {
  
  {- '<|im_start|>system\n' + messages[0]['content'] + '<|im_end|>\n' }}
    {%- else %}
        {
  
  {- '<|im_start|>system\nYou are Qwen, created by Alibaba Cloud. You are a helpful assistant.<|im_end|>\n' }}
    {%- endif %}
{%- endif %}
{%- for message in messages %} #遍历多轮对话信息
    {%- if (message.role == "user") or (message.role == "system" and not loop.first) or (message.role == "assistant" and not message.tool_calls) %}
        {
  
  {- '<|im_start|>' + message.role + '\n' + message.content + '<|im_end|>' + '\n' }}
    {%- elif message.role == "assistant" %}
        {
  
  {- '<|im_start|>' + message.role }}
        {%- if message.content %}
            {
  
  {- '\n' + message.content }}
        {%- endif %}
        {%- for tool_call in message.tool_calls %}
            {%- if tool_call.function is defined %}
                {%- set tool_call = tool_call.function %}
            {%- endif %}
            {
  
  {- '\n<tool_call>\n{"name": "' }}
            {
  
  {- tool_call.name }}
            {
  
  {- '", "arguments": ' }}
            {
  
  {- tool_call.arguments | tojson }}
            {
  
  {- '}\n</tool_call>' }}
        {%- endfor %}
        {
  
  {- '<|im_end|>\n' }}
    {%- elif message.role == "tool" %}
        {%- if (loop.index0 == 0) or (messages[loop.index0 - 1].role != "tool") %}
            {
  
  {- '<|im_start|>user' }}
        {%- endif %}
        {
  
  {- '\n<tool_response>\n' }}
        {
  
  {- message.content }}
        {
  
  {- '\n</tool_response>' }}
        {%- if loop.last or (messages[loop.index0 + 1].role != "tool") %}
            {
  
  {- '<|im_end|>\n' }}
        {%- endif %}
    {%- endif %}
{%- endfor %}
{%
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值