Skip to content
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

Parsing Error in bartowski/Lama.3.3-70B-Instruct-GGUF || Error: Failed to parse chat template: 12:21: error: Unexpected token: 'none' {%- set tools = none %} ---^------- #3305

Closed
DeNyMus1NeBiLon opened this issue Dec 16, 2024 · 3 comments · Fixed by #3327
Labels
bug-unconfirmed chat gpt4all-chat issues

Comments

@DeNyMus1NeBiLon
Copy link

DeNyMus1NeBiLon commented Dec 16, 2024

meta-issue: #3340

1. Description

After installing the bartowski/Lama.3.3-70B-Instruct-GGUF model, all interactions with the chat fail due to a parsing error. The issue occurs immediately when attempting to use the chat functionality.

Error Message:

Error: Failed to parse chat template:  
12:21: error: Unexpected token: 'none'  
{%- set tools = none %}  
       ---^-------

2. Steps to Reproduce

Install the bartowski/Lama.3.3-70B-Instruct-GGUF model following the documented installation process.
Start a chat session.
Attempt to interact with the chat.
The error occurs, and the system becomes entirely non-functional.

3. Expected Behavior

The chat interface should initialize and allow normal interactions without errors.

4. Actual Behavior

The parsing error blocks all further interactions. The system does not respond to any inputs, and no functionality is available.

Error Message:

Error: Failed to parse chat template:  
12:21: error: Unexpected token: 'none'  
{%- set tools = none %}  
       ---^-------

5. Environment

Operating System: Windows 11 Home
Hardware Specs:
Processor: 13th Gen Intel(R) Core(TM) i9-13980HX, 2200 MHz
Cores: 24 Core(s), 32 Logical Processor(s)
gpt4all Version: v.3.5.2

6. Screenshots/Logs
Image
Image

@DeNyMus1NeBiLon DeNyMus1NeBiLon added bug-unconfirmed chat gpt4all-chat issues labels Dec 16, 2024
@DeNyMus1NeBiLon
Copy link
Author

Chat Template

{{- bos_token }}
{%- if custom_tools is defined %}
    {%- set tools = custom_tools %}
{%- endif %}
{%- if not tools_in_user_message is defined %}
    {%- set tools_in_user_message = true %}
{%- endif %}
{%- if not date_string is defined %}
    {%- set date_string = "26 Jul 2024" %}
{%- endif %}
{%- if not tools is defined %}
    {%- set tools = none %}
{%- endif %}

{#- This block extracts the system message, so we can slot it into the right place. #}
{%- if messages[0]['role'] == 'system' %}
    {%- set system_message = messages[0]['content']|trim %}
    {%- set messages = messages[1:] %}
{%- else %}
    {%- set system_message = "" %}
{%- endif %}

{#- System message + builtin tools #}
{{- "<|start_header_id|>system<|end_header_id|>\n\n" }}
{%- if builtin_tools is defined or tools is not none %}
    {{- "Environment: ipython\n" }}
{%- endif %}
{%- if builtin_tools is defined %}
    {{- "Tools: " + builtin_tools | reject('equalto', 'code_interpreter') | join(", ") + "\n\n"}}
{%- endif %}
{{- "Cutting Knowledge Date: December 2023\n" }}
{{- "Today Date: " + date_string + "\n\n" }}
{%- if tools is not none and not tools_in_user_message %}
    {{- "You have access to the following functions. To call a function, please respond with JSON for a function call." }}
    {{- 'Respond in the format {"name": function name, "parameters": dictionary of argument name and its value}.' }}
    {{- "Do not use variables.\n\n" }}
    {%- for t in tools %}
        {{- t | tojson(indent=4) }}
        {{- "\n\n" }}
    {%- endfor %}
{%- endif %}
{{- system_message }}
{{- "<|eot_id|>" }}

{#- Custom tools are passed in a user message with some extra guidance #}
{%- if tools_in_user_message and not tools is none %}
    {#- Extract the first user message so we can plug it in here #}
    {%- if messages | length != 0 %}
        {%- set first_user_message = messages[0]['content']|trim %}
        {%- set messages = messages[1:] %}
    {%- else %}
        {{- raise_exception("Cannot put tools in the first user message when there's no first user message!") }}
{%- endif %}
    {{- '<|start_header_id|>user<|end_header_id|>\n\n' -}}
    {{- "Given the following functions, please respond with a JSON for a function call " }}
    {{- "with its proper arguments that best answers the given prompt.\n\n" }}
    {{- 'Respond in the format {"name": function name, "parameters": dictionary of argument name and its value}.' }}
    {{- "Do not use variables.\n\n" }}
    {%- for t in tools %}
        {{- t | tojson(indent=4) }}
        {{- "\n\n" }}
    {%- endfor %}
    {{- first_user_message + "<|eot_id|>"}}
{%- endif %}

{%- for message in messages %}
    {%- if not (message.role == 'ipython' or message.role == 'tool' or 'tool_calls' in message) %}
        {{- '<|start_header_id|>' + message['role'] + '<|end_header_id|>\n\n'+ message['content'] | trim + '<|eot_id|>' }}
    {%- elif 'tool_calls' in message %}
        {%- if not message.tool_calls|length == 1 %}
            {{- raise_exception("This model only supports single tool-calls at once!") }}
        {%- endif %}
        {%- set tool_call = message.tool_calls[0].function %}
        {%- if builtin_tools is defined and tool_call.name in builtin_tools %}
            {{- '<|start_header_id|>assistant<|end_header_id|>\n\n' -}}
            {{- "<|python_tag|>" + tool_call.name + ".call(" }}
            {%- for arg_name, arg_val in tool_call.arguments | items %}
                {{- arg_name + '="' + arg_val + '"' }}
                {%- if not loop.last %}
                    {{- ", " }}
                {%- endif %}
                {%- endfor %}
            {{- ")" }}
        {%- else  %}
            {{- '<|start_header_id|>assistant<|end_header_id|>\n\n' -}}
            {{- '{"name": "' + tool_call.name + '", ' }}
            {{- '"parameters": ' }}
            {{- tool_call.arguments | tojson }}
            {{- "}" }}
        {%- endif %}
        {%- if builtin_tools is defined %}
            {#- This means we're in ipython mode #}
            {{- "<|eom_id|>" }}
        {%- else %}
            {{- "<|eot_id|>" }}
        {%- endif %}
    {%- elif message.role == "tool" or message.role == "ipython" %}
        {{- "<|start_header_id|>ipython<|end_header_id|>\n\n" }}
        {%- if message.content is mapping or message.content is iterable %}
            {{- message.content | tojson }}
        {%- else %}
            {{- message.content }}
        {%- endif %}
        {{- "<|eot_id|>" }}
    {%- endif %}
{%- endfor %}
{%- if add_generation_prompt %}
    {{- '<|start_header_id|>assistant<|end_header_id|>\n\n' }}
{%- endif %}

@ThiloteE
Copy link
Collaborator

Similar errors as tracked in #3309

@art-lucas
Copy link

art-lucas commented Dec 17, 2024

Same issue with bartowski/Lama.3.3-70B-Instruct-GGUF model on GPT4All (December 16, 2024, v3.5.0) on macOS 14.7 (Sonoma).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug-unconfirmed chat gpt4all-chat issues
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants