-
Notifications
You must be signed in to change notification settings - Fork 222
Qwen3Coder unary/streaming output parser #3664
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from all commits
Commits
Show all changes
30 commits
Select commit
Hold shift + click to select a range
0428b48
Begin
atobiszei e6f0c21
Checkpoint
atobiszei 58fc69d
WIP
atobiszei d6cc713
Qwen3Coder bfcl - 0.95 simple/multiple
atobiszei 42d8e4b
Test fixes
atobiszei 3b8b620
Self-review
atobiszei 312eb9f
Self-review p2
atobiszei 198aef9
Spell fix
atobiszei 1b80de7
Streaming working
atobiszei 895330a
Style fixes
atobiszei c1a9c54
Add handling arguments in chat template in string format
atobiszei ea14b3b
Fix rebase
atobiszei 145726e
Fix Qwen3CoderBfcl test
atobiszei 47e0087
Unary & stream unification
atobiszei 36bf91d
Refactor cd
atobiszei 8dafe14
Refactor cd2
atobiszei 42d6fec
Logging fixes
atobiszei 55e4cc0
Self-review
atobiszei de5a859
Review fixes p1
atobiszei 900bb90
Merge branch 'main' into atobisze_qwen3_tool_parser
dtrawins 84ac218
Skip double tool schema parsing
atobiszei cbe4fab
Create rapidjson utils
atobiszei e70123f
Extend streaming test with another tool call
atobiszei 1023820
Output parsers build split
atobiszei 830869e
Merge remote-tracking branch 'origin/main' into atobisze_qwen3_tool_p…
atobiszei 33cd9f2
Fix BUILD file
atobiszei 9b8c2a3
Fix unconvential using
atobiszei e648478
Review fixes
atobiszei 649371d
Add ToolSchemaWrapper
atobiszei e7bca2d
Apply suggestion from @atobiszei
atobiszei File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
118 changes: 118 additions & 0 deletions
118
extras/chat_template_examples/chat_template_qwen3coder_instruct.jinja
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
{% macro render_extra_keys(json_dict, handled_keys) %} | ||
{%- if json_dict is mapping %} | ||
{%- for json_key in json_dict if json_key not in handled_keys %} | ||
{%- if json_dict[json_key] is mapping or (json_dict[json_key] is sequence and json_dict[json_key] is not string) %} | ||
{{- '\n<' ~ json_key ~ '>' ~ (json_dict[json_key] | tojson | safe) ~ '</' ~ json_key ~ '>' }} | ||
{%- else %} | ||
{{-'\n<' ~ json_key ~ '>' ~ (json_dict[json_key] | string) ~ '</' ~ json_key ~ '>' }} | ||
{%- endif %} | ||
{%- endfor %} | ||
{%- endif %} | ||
{% endmacro %} | ||
|
||
{%- if messages[0]["role"] == "system" %} | ||
{%- set system_message = messages[0]["content"] %} | ||
{%- set loop_messages = messages[1:] %} | ||
{%- else %} | ||
{%- set loop_messages = messages %} | ||
{%- endif %} | ||
|
||
{%- if not tools is defined %} | ||
{%- set tools = [] %} | ||
{%- endif %} | ||
|
||
{%- if system_message is defined %} | ||
{{- "<|im_start|>system\n" + system_message }} | ||
{%- else %} | ||
{%- if tools is iterable and tools | length > 0 %} | ||
{{- "<|im_start|>system\nYou are Qwen, a helpful AI assistant that can interact with a computer to solve tasks." }} | ||
{%- endif %} | ||
{%- endif %} | ||
{%- if tools is iterable and tools | length > 0 %} | ||
{{- "\n\n# Tools\n\nYou have access to the following functions:\n\n" }} | ||
{{- "<tools>" }} | ||
{%- for tool in tools %} | ||
{%- if tool.function is defined %} | ||
{%- set tool = tool.function %} | ||
{%- endif %} | ||
{{- "\n<function>\n<name>" ~ tool.name ~ "</name>" }} | ||
{%- if tool.description is defined %} | ||
{{- '\n<description>' ~ (tool.description | trim) ~ '</description>' }} | ||
{%- endif %} | ||
{{- '\n<parameters>' }} | ||
{%- if tool.parameters is defined and tool.parameters is mapping and tool.parameters.properties is defined and tool.parameters.properties is mapping %} | ||
{%- for param_name, param_fields in tool.parameters.properties|items %} | ||
{{- '\n<parameter>' }} | ||
{{- '\n<name>' ~ param_name ~ '</name>' }} | ||
{%- if param_fields.type is defined %} | ||
{{- '\n<type>' ~ (param_fields.type | string) ~ '</type>' }} | ||
{%- endif %} | ||
{%- if param_fields.description is defined %} | ||
{{- '\n<description>' ~ (param_fields.description | trim) ~ '</description>' }} | ||
{%- endif %} | ||
{%- set handled_keys = ['name', 'type', 'description'] %} | ||
{{- render_extra_keys(param_fields, handled_keys) }} | ||
{{- '\n</parameter>' }} | ||
{%- endfor %} | ||
{%- endif %} | ||
{% set handled_keys = ['type', 'properties'] %} | ||
{{- render_extra_keys(tool.parameters, handled_keys) }} | ||
{{- '\n</parameters>' }} | ||
{%- set handled_keys = ['type', 'name', 'description', 'parameters'] %} | ||
{{- render_extra_keys(tool, handled_keys) }} | ||
{{- '\n</function>' }} | ||
{%- endfor %} | ||
{{- "\n</tools>" }} | ||
{{- '\n\nIf you choose to call a function ONLY reply in the following format with NO suffix:\n\n<tool_call>\n<function=example_function_name>\n<parameter=example_parameter_1>\nvalue_1\n</parameter>\n<parameter=example_parameter_2>\nThis is the value for the second parameter\nthat can span\nmultiple lines\n</parameter>\n</function>\n</tool_call>\n\n<IMPORTANT>\nReminder:\n- Function calls MUST follow the specified format: an inner <function=...></function> block must be nested within <tool_call></tool_call> XML tags\n- Required parameters MUST be specified\n- You may provide optional reasoning for your function call in natural language BEFORE the function call, but NOT after\n- If there is no function call available, answer the question like normal with your current knowledge and do not tell the user about function calls\n</IMPORTANT>' }} | ||
{%- endif %} | ||
{%- if system_message is defined %} | ||
{{- '<|im_end|>\n' }} | ||
{%- else %} | ||
{%- if tools is iterable and tools | length > 0 %} | ||
{{- '<|im_end|>\n' }} | ||
{%- endif %} | ||
{%- endif %} | ||
{%- for message in loop_messages %} | ||
{%- if message.role == "assistant" and message.tool_calls is defined and message.tool_calls is iterable and message.tool_calls | length > 0 %} | ||
{{- '<|im_start|>' + message.role }} | ||
{%- if message.content is defined and message.content is string and message.content | trim | length > 0 %} | ||
{{- '\n' + message.content | trim + '\n' }} | ||
{%- 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<function=' + tool_call.name + '>\n' }} | ||
{%- if tool_call.arguments is defined %} | ||
{%- set arguments = tool_call.arguments | from_json %} | ||
{%- for args_name, args_value in arguments|items %} | ||
{{- '<parameter=' + args_name + '>\n' }} | ||
{%- set args_value = args_value | tojson | safe if args_value is mapping or (args_value is sequence and args_value is not string) else args_value | string %} | ||
{{- args_value }} | ||
{{- '\n</parameter>\n' }} | ||
{%- endfor %} | ||
{%- endif %} | ||
{{- '</function>\n</tool_call>' }} | ||
{%- endfor %} | ||
{{- '<|im_end|>\n' }} | ||
{%- elif message.role == "user" or message.role == "system" or message.role == "assistant" %} | ||
{{- '<|im_start|>' + message.role + '\n' + message.content + '<|im_end|>' + '\n' }} | ||
{%- elif message.role == "tool" %} | ||
{%- if loop.previtem and loop.previtem.role != "tool" %} | ||
{{- '<|im_start|>user\n' }} | ||
{%- endif %} | ||
{{- '<tool_response>\n' }} | ||
{{- message.content }} | ||
{{- '\n</tool_response>\n' }} | ||
{%- if not loop.last and loop.nextitem.role != "tool" %} | ||
{{- '<|im_end|>\n' }} | ||
{%- elif loop.last %} | ||
{{- '<|im_end|>\n' }} | ||
{%- endif %} | ||
{%- else %} | ||
{{- '<|im_start|>' + message.role + '\n' + message.content + '<|im_end|>\n' }} | ||
{%- endif %} | ||
{%- endfor %} | ||
{%- if add_generation_prompt %} | ||
{{- '<|im_start|>assistant\n' }} | ||
{%- endif %} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
//***************************************************************************** | ||
// Copyright 2025 Intel Corporation | ||
// | ||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||
// you may not use this file except in compliance with the License. | ||
// You may obtain a copy of the License at | ||
// | ||
// http://www.apache.org/licenses/LICENSE-2.0 | ||
// | ||
// Unless required by applicable law or agreed to in writing, software | ||
// distributed under the License is distributed on an "AS IS" BASIS, | ||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
//***************************************************************************** | ||
|
||
// Type that holds vector of pairs where first element is chat turn index and second is image tensor | ||
// this way we store information about which image is associated with which chat turn | ||
#pragma once | ||
#include <map> | ||
#include <string> | ||
|
||
#include "src/port/rapidjson_document.hpp" | ||
|
||
namespace ovms { | ||
struct ToolSchemaWrapper { | ||
rapidjson::Value* rapidjsonRepr; | ||
std::string stringRepr; | ||
}; | ||
using ToolsSchemas_t = std::map<std::string, ToolSchemaWrapper>; | ||
} // namespace ovms |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.