|
<?xml version="1.0"?>
|
|
<net name="detokenizer" version="11">
|
|
<layers>
|
|
<layer id="0" name="Parameter_420741" type="Parameter" version="opset1">
|
|
<data shape="?,?" element_type="i64" />
|
|
<output>
|
|
<port id="0" precision="I64" names="Parameter_420741">
|
|
<dim>-1</dim>
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="1" name="Convert_420752" type="Convert" version="opset1">
|
|
<data destination_type="i32" />
|
|
<input>
|
|
<port id="0" precision="I64">
|
|
<dim>-1</dim>
|
|
<dim>-1</dim>
|
|
</port>
|
|
</input>
|
|
<output>
|
|
<port id="1" precision="I32">
|
|
<dim>-1</dim>
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="2" name="Constant_420644" type="Const" version="opset1">
|
|
<data element_type="u8" shape="1976445" offset="0" size="1976445" />
|
|
<output>
|
|
<port id="0" precision="U8">
|
|
<dim>1976445</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="3" name="StringTensorUnpack_420645" type="StringTensorUnpack" version="extension">
|
|
<data mode="begins_ends" />
|
|
<input>
|
|
<port id="0" precision="U8">
|
|
<dim>1976445</dim>
|
|
</port>
|
|
</input>
|
|
<output>
|
|
<port id="1" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="2" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="3" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="4" name="VocabDecoder_420742" type="VocabDecoder" version="extension">
|
|
<data skip_tokens="151643, 151644, 151645, 151646, 151647, 151648, 151649, 151650, 151651, 151652, 151653, 151654, 151655, 151656" />
|
|
<input>
|
|
<port id="0" precision="I32">
|
|
<dim>-1</dim>
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="1" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="2" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="3" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</input>
|
|
<output>
|
|
<port id="4" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="5" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="6" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="7" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="8" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="5" name="CharsToBytes_420743" type="CharsToBytes" version="extension">
|
|
<input>
|
|
<port id="0" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="1" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="2" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="3" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="4" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</input>
|
|
<output>
|
|
<port id="5" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="6" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="7" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="6" name="StringTensorPack_420744" type="StringTensorPack" version="extension">
|
|
<data mode="begins_ends" />
|
|
<input>
|
|
<port id="0" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="1" precision="I32">
|
|
<dim>-1</dim>
|
|
</port>
|
|
<port id="2" precision="U8">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</input>
|
|
<output>
|
|
<port id="3" precision="STRING" names="string_output">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</output>
|
|
</layer>
|
|
<layer id="7" name="Result_420745" type="Result" version="opset1">
|
|
<input>
|
|
<port id="0" precision="STRING">
|
|
<dim>-1</dim>
|
|
</port>
|
|
</input>
|
|
</layer>
|
|
</layers>
|
|
<edges>
|
|
<edge from-layer="0" from-port="0" to-layer="1" to-port="0" />
|
|
<edge from-layer="1" from-port="1" to-layer="4" to-port="0" />
|
|
<edge from-layer="2" from-port="0" to-layer="3" to-port="0" />
|
|
<edge from-layer="3" from-port="1" to-layer="4" to-port="1" />
|
|
<edge from-layer="3" from-port="2" to-layer="4" to-port="2" />
|
|
<edge from-layer="3" from-port="3" to-layer="4" to-port="3" />
|
|
<edge from-layer="4" from-port="4" to-layer="5" to-port="0" />
|
|
<edge from-layer="4" from-port="5" to-layer="5" to-port="1" />
|
|
<edge from-layer="4" from-port="6" to-layer="5" to-port="2" />
|
|
<edge from-layer="4" from-port="7" to-layer="5" to-port="3" />
|
|
<edge from-layer="4" from-port="8" to-layer="5" to-port="4" />
|
|
<edge from-layer="5" from-port="5" to-layer="6" to-port="0" />
|
|
<edge from-layer="5" from-port="6" to-layer="6" to-port="1" />
|
|
<edge from-layer="5" from-port="7" to-layer="6" to-port="2" />
|
|
<edge from-layer="6" from-port="3" to-layer="7" to-port="0" />
|
|
</edges>
|
|
<rt_info>
|
|
<chat_template value="{%- 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 %} {%- if add_generation_prompt %} {{- '<|im_start|>assistant\n' }} {%- endif %} " />
|
|
<eos_token_id value="151645" />
|
|
<original_tokenizer_class value="<class 'transformers.models.qwen2.tokenization_qwen2_fast.Qwen2TokenizerFast'>" />
|
|
<pad_token_id value="151643" />
|
|
</rt_info>
|
|
</net>
|
|
|