|
<?xml version="1.0"?> |
|
<net name="detokenizer" version="11"> |
|
<layers> |
|
<layer id="0" name="Parameter_102301" type="Parameter" version="opset1"> |
|
<data shape="?,?" element_type="i64" /> |
|
<output> |
|
<port id="0" precision="I64" names="Parameter_102301"> |
|
<dim>-1</dim> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="1" name="Convert_102496" 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_102254" type="Const" version="opset1"> |
|
<data element_type="i32" shape="32768" offset="0" size="131072" /> |
|
<output> |
|
<port id="0" precision="I32"> |
|
<dim>32768</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="3" name="Constant_102256" type="Const" version="opset1"> |
|
<data element_type="i32" shape="32768" offset="131072" size="131072" /> |
|
<output> |
|
<port id="0" precision="I32"> |
|
<dim>32768</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="4" name="Constant_102258" type="Const" version="opset1"> |
|
<data element_type="u8" shape="214558" offset="262144" size="214558" /> |
|
<output> |
|
<port id="0" precision="U8"> |
|
<dim>214558</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="5" name="Slice_102306" type="Const" version="opset1"> |
|
<data element_type="i32" shape="771" offset="476702" size="3084" /> |
|
<output> |
|
<port id="0" precision="I32"> |
|
<dim>771</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="6" name="VocabDecoder_102308" type="VocabDecoder" version="extension"> |
|
<data skip_tokens="" /> |
|
<input> |
|
<port id="0" precision="I32"> |
|
<dim>-1</dim> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="1" precision="I32"> |
|
<dim>32768</dim> |
|
</port> |
|
<port id="2" precision="I32"> |
|
<dim>32768</dim> |
|
</port> |
|
<port id="3" precision="U8"> |
|
<dim>214558</dim> |
|
</port> |
|
<port id="4" precision="I32"> |
|
<dim>771</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="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="8" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="9" precision="U8"> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="7" name="Constant_102310" type="Const" version="opset1"> |
|
<data element_type="u8" shape="3" offset="479786" size="3" /> |
|
<output> |
|
<port id="0" precision="U8"> |
|
<dim>3</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="8" name="Constant_102312" type="Const" version="opset1"> |
|
<data element_type="u8" shape="1" offset="479789" size="1" /> |
|
<output> |
|
<port id="0" precision="U8"> |
|
<dim>1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="9" name="RegexNormalization_102313" type="RegexNormalization" version="extension"> |
|
<data global_replace="true" /> |
|
<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> |
|
<port id="3" precision="U8"> |
|
<dim>3</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="10" name="ByteFallback_102314" type="ByteFallback" 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="U8"> |
|
<dim>-1</dim> |
|
</port> |
|
</input> |
|
<output> |
|
<port id="3" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="4" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="5" precision="U8"> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="11" name="FuzeRagged_102315" type="FuzeRagged" 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> |
|
</input> |
|
<output> |
|
<port id="4" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="5" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="12" name="Constant_102317" type="Const" version="opset1"> |
|
<data element_type="u8" shape="2" offset="479790" size="2" /> |
|
<output> |
|
<port id="0" precision="U8"> |
|
<dim>2</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="13" name="Constant_102319" type="Const" version="opset1"> |
|
<data element_type="u8" shape="0" offset="479792" size="1" /> |
|
<output> |
|
<port id="0" precision="U8"> |
|
<dim>0</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="14" name="RegexNormalization_102320" type="RegexNormalization" version="extension"> |
|
<data global_replace="true" /> |
|
<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> |
|
<port id="3" precision="U8"> |
|
<dim>2</dim> |
|
</port> |
|
<port id="4" precision="U8"> |
|
<dim>0</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="15" name="UTF8Validate_102321" type="UTF8Validate" version="extension"> |
|
<data replace_mode="true" /> |
|
<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="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="4" precision="I32"> |
|
<dim>-1</dim> |
|
</port> |
|
<port id="5" precision="U8"> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="16" name="StringTensorPack_102322" type="StringTensorPack" version="opset15"> |
|
<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="Result_102323,string_output"> |
|
<dim>-1</dim> |
|
</port> |
|
</output> |
|
</layer> |
|
<layer id="17" name="Result_102323" type="Result" version="opset1" output_names="Result_102323,string_output"> |
|
<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="6" to-port="0" /> |
|
<edge from-layer="2" from-port="0" to-layer="6" to-port="1" /> |
|
<edge from-layer="3" from-port="0" to-layer="6" to-port="2" /> |
|
<edge from-layer="4" from-port="0" to-layer="6" to-port="3" /> |
|
<edge from-layer="5" from-port="0" to-layer="6" to-port="4" /> |
|
<edge from-layer="6" from-port="6" to-layer="11" to-port="1" /> |
|
<edge from-layer="6" from-port="5" to-layer="11" to-port="0" /> |
|
<edge from-layer="6" from-port="8" to-layer="9" to-port="1" /> |
|
<edge from-layer="6" from-port="7" to-layer="9" to-port="0" /> |
|
<edge from-layer="6" from-port="9" to-layer="9" to-port="2" /> |
|
<edge from-layer="7" from-port="0" to-layer="9" to-port="3" /> |
|
<edge from-layer="8" from-port="0" to-layer="9" to-port="4" /> |
|
<edge from-layer="9" from-port="5" to-layer="10" to-port="0" /> |
|
<edge from-layer="9" from-port="6" to-layer="10" to-port="1" /> |
|
<edge from-layer="9" from-port="7" to-layer="10" to-port="2" /> |
|
<edge from-layer="10" from-port="3" to-layer="11" to-port="2" /> |
|
<edge from-layer="10" from-port="4" to-layer="11" to-port="3" /> |
|
<edge from-layer="10" from-port="5" to-layer="14" to-port="2" /> |
|
<edge from-layer="11" from-port="5" to-layer="14" to-port="1" /> |
|
<edge from-layer="11" from-port="4" to-layer="14" to-port="0" /> |
|
<edge from-layer="12" from-port="0" to-layer="14" to-port="3" /> |
|
<edge from-layer="13" from-port="0" to-layer="14" to-port="4" /> |
|
<edge from-layer="14" from-port="5" to-layer="15" to-port="0" /> |
|
<edge from-layer="14" from-port="6" to-layer="15" to-port="1" /> |
|
<edge from-layer="14" from-port="7" to-layer="15" to-port="2" /> |
|
<edge from-layer="15" from-port="3" to-layer="16" to-port="0" /> |
|
<edge from-layer="15" from-port="4" to-layer="16" to-port="1" /> |
|
<edge from-layer="15" from-port="5" to-layer="16" to-port="2" /> |
|
<edge from-layer="16" from-port="3" to-layer="17" to-port="0" /> |
|
</edges> |
|
<rt_info> |
|
<add_attention_mask value="True" /> |
|
<add_prefix_space /> |
|
<add_special_tokens value="True" /> |
|
<bos_token_id value="1" /> |
|
<chat_template value="{%- 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 = none %} {%- endif %} {%- set user_messages = loop_messages | selectattr("role", "equalto", "user") | list %} {#- This block checks for alternating user/assistant messages, skipping tool calling messages #} {%- set ns = namespace() %} {%- set ns.index = 0 %} {%- for message in loop_messages %} {%- if not (message.role == "tool" or message.role == "tool_results" or (message.tool_calls is defined and message.tool_calls is not none)) %} {%- if (message["role"] == "user") != (ns.index % 2 == 0) %} {{- raise_exception("After the optional system message, conversation roles must alternate user/assistant/user/assistant/...") }} {%- endif %} {%- set ns.index = ns.index + 1 %} {%- endif %} {%- endfor %} {{- bos_token }} {%- for message in loop_messages %} {%- if message["role"] == "user" %} {%- if tools is not none and (message == user_messages[-1]) %} {{- "[AVAILABLE_TOOLS] [" }} {%- for tool in tools %} {%- set tool = tool.function %} {{- '{"type": "function", "function": {' }} {%- for key, val in tool.items() if key != "return" %} {%- if val is string %} {{- '"' + key + '": "' + val + '"' }} {%- else %} {{- '"' + key + '": ' + val|tojson }} {%- endif %} {%- if not loop.last %} {{- ", " }} {%- endif %} {%- endfor %} {{- "}}" }} {%- if not loop.last %} {{- ", " }} {%- else %} {{- "]" }} {%- endif %} {%- endfor %} {{- "[/AVAILABLE_TOOLS]" }} {%- endif %} {%- if loop.last and system_message is defined %} {{- "[INST] " + system_message + "\n\n" + message["content"] + "[/INST]" }} {%- else %} {{- "[INST] " + message["content"] + "[/INST]" }} {%- endif %} {%- elif message.tool_calls is defined and message.tool_calls is not none %} {{- "[TOOL_CALLS] [" }} {%- for tool_call in message.tool_calls %} {%- set out = tool_call.function|tojson %} {{- out[:-1] }} {%- if not tool_call.id is defined or tool_call.id|length != 9 %} {{- raise_exception("Tool call IDs should be alphanumeric strings with length 9!") }} {%- endif %} {{- ', "id": "' + tool_call.id + '"}' }} {%- if not loop.last %} {{- ", " }} {%- else %} {{- "]" + eos_token }} {%- endif %} {%- endfor %} {%- elif message["role"] == "assistant" %} {{- " " + message["content"]|trim + eos_token}} {%- elif message["role"] == "tool_results" or message["role"] == "tool" %} {%- if message.content is defined and message.content.content is defined %} {%- set content = message.content.content %} {%- else %} {%- set content = message.content %} {%- endif %} {{- '[TOOL_RESULTS] {"content": ' + content|string + ", " }} {%- if not message.tool_call_id is defined or message.tool_call_id|length != 9 %} {{- raise_exception("Tool call IDs should be alphanumeric strings with length 9!") }} {%- endif %} {{- '"call_id": "' + message.tool_call_id + '"}[/TOOL_RESULTS]' }} {%- else %} {{- raise_exception("Only user and assistant roles are supported, with the exception of an initial optional system message!") }} {%- endif %} {%- endfor %} " /> |
|
<clean_up_tokenization_spaces /> |
|
<detokenizer_input_type value="i64" /> |
|
<eos_token_id value="2" /> |
|
<handle_special_tokens_with_re /> |
|
<max_length /> |
|
<number_of_inputs value="1" /> |
|
<openvino_tokenizers_version value="2025.2.0.0-566-85be884a69f" /> |
|
<openvino_version value="2025.2.0-19136-649eec15cfe-releases/2025/2" /> |
|
<original_post_processor_template value="{"type": "TemplateProcessing", "single": [{"SpecialToken": {"id": "<s>", "type_id": 0}}, {"Sequence": {"id": "A", "type_id": 0}}], "pair": [{"SpecialToken": {"id": "<s>", "type_id": 0}}, {"Sequence": {"id": "A", "type_id": 0}}, {"SpecialToken": {"id": "<s>", "type_id": 1}}, {"Sequence": {"id": "B", "type_id": 1}}], "special_tokens": {"<s>": {"id": "<s>", "ids": [1], "tokens": ["<s>"]}}}" /> |
|
<original_tokenizer_class value="<class 'transformers.models.llama.tokenization_llama_fast.LlamaTokenizerFast'>" /> |
|
<processed_post_processor_template value="{"single": {"ids": [1, -1], "type_ids": [0, 0]}, "pair": {"ids": [1, -1, 1, -2], "type_ids": [0, 0, 1, 1]}}" /> |
|
<sentencepiece_version value="0.2.0" /> |
|
<skip_special_tokens value="True" /> |
|
<streaming_detokenizer value="False" /> |
|
<tiktoken_version value="0.9.0" /> |
|
<tokenizer_output_type value="i64" /> |
|
<tokenizers_version value="0.21.1" /> |
|
<transformers_version value="4.51.3" /> |
|
<use_max_padding value="False" /> |
|
<use_sentencepiece_backend value="False" /> |
|
<utf8_replace_mode value="replace" /> |
|
<with_detokenizer value="True" /> |
|
</rt_info> |
|
</net> |
|
|