2024-04-25 13:25:56 -04:00
|
|
|
---
|
2024-04-23 19:35:45 +02:00
|
|
|
name: "hermes-2-pro-mistral"
|
|
|
|
|
|
|
|
config_file: |
|
|
|
|
mmap: true
|
2024-05-23 19:16:08 +02:00
|
|
|
context_size: 8192
|
2024-05-22 00:14:16 +02:00
|
|
|
stopwords:
|
|
|
|
- "<|im_end|>"
|
|
|
|
- "<dummy32000>"
|
|
|
|
- "<|eot_id|>"
|
|
|
|
- "<|end_of_text|>"
|
|
|
|
function:
|
|
|
|
disable_no_action: true
|
2024-06-21 19:41:49 +02:00
|
|
|
grammar:
|
|
|
|
# Uncomment the line below to enable grammar matching for JSON results if the model is breaking
|
|
|
|
# the output. This will make the model more accurate and won't break the JSON output.
|
|
|
|
# This however, will make parallel_calls not functional (it is a known bug)
|
|
|
|
# mixed_mode: true
|
2024-06-23 15:17:41 +02:00
|
|
|
disable: true
|
2024-06-21 19:41:49 +02:00
|
|
|
parallel_calls: true
|
|
|
|
expect_strings_after_json: true
|
2024-05-22 00:14:16 +02:00
|
|
|
json_regex_match:
|
|
|
|
- "(?s)<tool_call>(.*?)</tool_call>"
|
2024-06-21 19:41:49 +02:00
|
|
|
- "(?s)<tool_call>(.*)"
|
|
|
|
capture_llm_results:
|
|
|
|
- (?s)<scratchpad>(.*?)</scratchpad>
|
2024-05-22 00:14:16 +02:00
|
|
|
replace_llm_results:
|
2024-06-21 19:41:49 +02:00
|
|
|
- key: (?s)<scratchpad>(.*?)</scratchpad>
|
|
|
|
value: ""
|
2024-05-22 00:14:16 +02:00
|
|
|
|
2024-04-23 19:35:45 +02:00
|
|
|
template:
|
2024-05-22 00:14:16 +02:00
|
|
|
chat: |
|
|
|
|
{{.Input -}}
|
|
|
|
<|im_start|>assistant
|
2024-04-23 19:35:45 +02:00
|
|
|
chat_message: |
|
|
|
|
<|im_start|>{{if eq .RoleName "assistant"}}assistant{{else if eq .RoleName "system"}}system{{else if eq .RoleName "tool"}}tool{{else if eq .RoleName "user"}}user{{end}}
|
|
|
|
{{- if .FunctionCall }}
|
|
|
|
<tool_call>
|
|
|
|
{{- else if eq .RoleName "tool" }}
|
|
|
|
<tool_response>
|
|
|
|
{{- end }}
|
|
|
|
{{- if .Content}}
|
|
|
|
{{.Content }}
|
|
|
|
{{- end }}
|
|
|
|
{{- if .FunctionCall}}
|
|
|
|
{{toJson .FunctionCall}}
|
|
|
|
{{- end }}
|
|
|
|
{{- if .FunctionCall }}
|
|
|
|
</tool_call>
|
|
|
|
{{- else if eq .RoleName "tool" }}
|
|
|
|
</tool_response>
|
2024-04-25 01:28:02 +02:00
|
|
|
{{- end }}<|im_end|>
|
2024-05-22 00:14:16 +02:00
|
|
|
completion: |
|
|
|
|
{{.Input}}
|
2024-06-21 19:41:49 +02:00
|
|
|
function: |
|
2024-04-23 19:35:45 +02:00
|
|
|
<|im_start|>system
|
2024-05-22 00:14:16 +02:00
|
|
|
You are a function calling AI model.
|
|
|
|
Here are the available tools:
|
2024-04-23 19:35:45 +02:00
|
|
|
<tools>
|
|
|
|
{{range .Functions}}
|
|
|
|
{'type': 'function', 'function': {'name': '{{.Name}}', 'description': '{{.Description}}', 'parameters': {{toJson .Parameters}} }}
|
|
|
|
{{end}}
|
|
|
|
</tools>
|
2024-05-22 00:14:16 +02:00
|
|
|
You should call the tools provided to you sequentially
|
|
|
|
Please use <scratchpad> XML tags to record your reasoning and planning before you call the functions as follows:
|
|
|
|
<scratchpad>
|
|
|
|
{step-by-step reasoning and plan in bullet points}
|
|
|
|
</scratchpad>
|
|
|
|
For each function call return a json object with function name and arguments within <tool_call> XML tags as follows:
|
2024-04-23 19:35:45 +02:00
|
|
|
<tool_call>
|
2024-05-22 00:14:16 +02:00
|
|
|
{"arguments": <args-dict>, "name": <function-name>}
|
2024-04-25 01:28:02 +02:00
|
|
|
</tool_call><|im_end|>
|
2024-04-23 19:35:45 +02:00
|
|
|
{{.Input -}}
|
|
|
|
<|im_start|>assistant
|