{ "add_bos_token": true, "add_eos_token": false, "add_prefix_space": null, "added_tokens_decoder": { "0": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "1": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "2": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "3": { "content": "0", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "4": { "content": "1", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "5": { "content": "2", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "6": { "content": "3", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "7": { "content": "4", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "8": { "content": "5", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "9": { "content": "6", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "10": { "content": "7", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "11": { "content": "8", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "12": { "content": "9", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100272": { "content": "<|end_of_sentence|>", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "100273": { "content": "<|begin_of_sentence|>", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "100274": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "100281": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true }, "100282": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100295": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100296": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100297": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100298": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100299": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100300": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100301": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100302": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100303": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100304": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100305": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100306": { "content": "", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100307": { "content": "<|im_start|>", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": false }, "100308": { "content": "<|im_end|>", "lstrip": false, "normalized": false, "rstrip": false, "single_word": false, "special": true } }, "additional_special_tokens": [], "bos_token": "", "clean_up_tokenization_spaces": false, "cls_token": "<|begin_of_sentence|>", "eos_token": "", "extra_special_tokens": {}, "header_end_token": "", "header_start_token": "", "legacy": true, "mask_token": "", "model_max_length": 131072, "pad_token": "", "padding_side": "left", "sep_token": "<|end_of_sentence|>", "sys_end_token": "", "sys_start_token": "", "tokenizer_class": "LlamaTokenizer", "unk_token": "", "use_default_system_prompt": false, "chat_template": "{# Unsloth template fixes #}{{- '<|im_start|>system\n' }}{%- if messages[0].role != 'system' and not system_settings %}{{- '\nthink_mode=True\n' }}{%- else%}{{- '\n' }}{{- system_settings + '\n' if system_settings else '' }}{{- (messages[0].content + '\n' if messages[0].role == 'system' else '') + '\n\n\nthink_mode=True\n' }}{%- endif %}{%- if tools %}{{- \"\n\n\" }}{{- '\n' }}{{-'['}}{% for tool in tools %}{{'{\"type\": \"function\", \"function\": '}}{{-(tool.function | tojson)}}}{%-if not loop.last%},{%- endif %}{%endfor%}{{-']'}}{{- \"\n\" }}{%- endif %}{{-'<|im_end|>\n\n' }}{%- set ns = namespace(multi_step_tool=true, last_query_index=messages|length - 1) %}\n{%- for message in messages[::-1] %}\n {%- set index = (messages|length - 1) - loop.index0 %}\n {%- if ns.multi_step_tool and message.role == \"user\" and message.content is string and not(message.content.startswith('') and message.content.endswith('')) %}\n {%- set ns.multi_step_tool = false %}\n {%- set ns.last_query_index = index %}\n {%- endif %}\n{%- endfor %}\n{%- for message in messages %}\n {%- if message.content is string %}\n {%- set content = message.content %}\n {%- else %}\n {%- set content = '' %}\n {%- endif %}\n {%- if (message.role == \"user\") or (message.role == \"system\" and not loop.first) %}\n {{- '<|im_start|>' + message.role + '\n' + content + '<|im_end|>' + '\n\n' }}\n {%- elif message.role == \"assistant\" %}\n {%- set reasoning_content = '' %}\n {%- if message.thoughts is string %}\n {%- set reasoning_content = message.thoughts %}\n {%- else %}\n {# Unsloth template fixes - must change to for loop since llama.cpp will error out if not #}\n {%- set parts = content.split('') %}\n {%- for part in parts %}\n {%- if loop.index0 == 0 -%}\n {%- set reasoning_content = (part.split(\"\")|last) %}\n {%- set reasoning_content = reasoning_content.lstrip('\\n').rstrip('\\n') -%}\n {%- else -%}\n {%- set content = part.lstrip('\\n') %}\n {%- endif %}\n {%- endfor %}\n {%- endif %}\n {%- if loop.index0 > ns.last_query_index and (loop.last or (not loop.last and reasoning_content)) %} {{- '<|im_start|>' + message.role + '\n\n' + reasoning_content.strip('\n') + '\n\n' }} {%- else %} {{- '<|im_start|>' + message.role + '\n' }} {%- endif %} {%- if content|length > 0 %} {{- '\n' + content + '\n\n' }} {%- endif %} {%- if message.tool_calls %}\n {%- for tool_call in message.tool_calls %}\n {%- if (loop.first and content) or (not loop.first) %}\n {{- '\n' }}\n {%- endif %}\n {%- if tool_call.function %}\n {%- set tool_call = tool_call.function %}\n {%- endif %}\n {{- '\n\n{\"name\": \"' }}\n {{- tool_call.name }}\n {{- '\", \"arguments\": ' }}\n {%- if tool_call.arguments is string %}\n {{- tool_call.arguments }}\n {%- else %}\n {{- tool_call.arguments | tojson }}\n {%- endif %}\n {{- '}\n\n' }}\n {%- endfor %}\n {%- endif %}\n {{- '<|im_end|>\n\n' }}\n {%- elif message.role == \"tool\" %}\n {%- if loop.first or (messages[loop.index0 - 1].role != \"tool\") %}\n {{- '<|im_start|>tool' }}\n {%- endif %}\n {{- '\n' }}\n {{- message.content|tojson }}\n {{- '' }}\n {%- if loop.last or (messages[loop.index0 + 1].role != \"tool\") %}\n {{- '<|im_end|>\n\n' }}\n {%- endif %}\n {%- endif %}\n{%- endfor %}\n {%- if add_generation_prompt is defined and add_generation_prompt %}\n {{- \"<|im_start|>assistant\n\n\"}}\n{%- endif %}\n{# Copyright 2025-present Unsloth. Apache 2.0 License. #}" }