Merge pull request #5639 from ollama/mxyng/unaggregated-system
This commit is contained in:
commit
47353f5ee4
24 changed files with 124 additions and 258 deletions
|
@ -546,8 +546,8 @@ func TestCreateDetectTemplate(t *testing.T) {
|
||||||
|
|
||||||
checkFileExists(t, filepath.Join(p, "blobs", "*"), []string{
|
checkFileExists(t, filepath.Join(p, "blobs", "*"), []string{
|
||||||
filepath.Join(p, "blobs", "sha256-553c4a3f747b3d22a4946875f1cc8ed011c2930d83f864a0c7265f9ec0a20413"),
|
filepath.Join(p, "blobs", "sha256-553c4a3f747b3d22a4946875f1cc8ed011c2930d83f864a0c7265f9ec0a20413"),
|
||||||
filepath.Join(p, "blobs", "sha256-68b0323b2f21572bc09ba07554b16b379a5713ee48ef8c25a7661a1f71cfce77"),
|
filepath.Join(p, "blobs", "sha256-c608dc615584cd20d9d830363dabf8a4783ae5d34245c3d8c115edb3bc7b28e4"),
|
||||||
filepath.Join(p, "blobs", "sha256-eb72fb7c550ee1f1dec4039bd65382acecf5f7536a30fb7ccace39a8d0cb590b"),
|
filepath.Join(p, "blobs", "sha256-f836ee110db21567f826332e4cedd746c06d10664fd5a9ea3659e3683a944510"),
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}<start_system>{{ .System }}<end_message>
|
|
||||||
{{- end }}
|
|
||||||
{{- range .Messages }}<start_{{ .Role }}>{{ .Content }}<end_message>
|
|
||||||
{{- end }}<start_assistant>
|
|
||||||
{{- else -}}
|
|
||||||
{{ if .System }}<start_system>{{ .System }}<end_message>{{ end }}{{ if .Prompt }}<start_user>{{ .Prompt }}<end_message>{{ end }}<start_assistant>{{ .Response }}<end_message>
|
{{ if .System }}<start_system>{{ .System }}<end_message>{{ end }}{{ if .Prompt }}<start_user>{{ .Prompt }}<end_message>{{ end }}<start_assistant>{{ .Response }}<end_message>
|
||||||
{{- end -}}
|
|
|
@ -1,15 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}### Instruction:
|
|
||||||
{{- else if eq .Role "assistant" }}### Response:
|
|
||||||
{{- end }}
|
|
||||||
{{ .Content }}
|
|
||||||
|
|
||||||
{{ end }}### Response:
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}{{ .System }}
|
{{ if .System }}{{ .System }}
|
||||||
|
|
||||||
{{ end }}{{ if .Prompt }}### Instruction:
|
{{ end }}{{ if .Prompt }}### Instruction:
|
||||||
|
@ -18,4 +6,3 @@
|
||||||
{{ end }}### Response:
|
{{ end }}### Response:
|
||||||
{{ .Response }}
|
{{ .Response }}
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -1,15 +1,6 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}<|im_start|>system
|
|
||||||
{{ .System }}<|im_end|>
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}<|im_start|>{{ .Role }}
|
|
||||||
{{ .Content }}<|im_end|>
|
|
||||||
{{ end }}<|im_start|>assistant
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}<|im_start|>system
|
{{ if .System }}<|im_start|>system
|
||||||
{{ .System }}<|im_end|>
|
{{ .System }}<|im_end|>
|
||||||
{{ end }}{{ if .Prompt }}<|im_start|>user
|
{{ end }}{{ if .Prompt }}<|im_start|>user
|
||||||
{{ .Prompt }}<|im_end|>
|
{{ .Prompt }}<|im_end|>
|
||||||
{{ end }}<|im_start|>assistant
|
{{ end }}<|im_start|>assistant
|
||||||
{{ .Response }}<|im_end|>
|
{{ .Response }}<|im_end|>
|
||||||
{{ end -}}
|
|
|
@ -1,18 +1,6 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}System: {{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}User:
|
|
||||||
{{- else if eq .Role "assistant" }}Assistant:
|
|
||||||
{{- end }} {{ .Content }}
|
|
||||||
|
|
||||||
{{ end }}Assistant:
|
|
||||||
{{- else -}}
|
|
||||||
{{ if .System }}System: {{ .System }}
|
{{ if .System }}System: {{ .System }}
|
||||||
|
|
||||||
{{ end }}{{ if .Prompt }}User: {{ .Prompt }}
|
{{ end }}{{ if .Prompt }}User: {{ .Prompt }}
|
||||||
|
|
||||||
{{ end }}Assistant: {{ .Response }}
|
{{ end }}Assistant: {{ .Response }}
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -1,19 +1,10 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}Source: system
|
|
||||||
|
|
||||||
{{ .System }} <step> {{ end }}
|
|
||||||
{{- range .Messages }}Source: {{ .Role }}
|
|
||||||
|
|
||||||
{{ .Content }} <step> {{ end }}Source: assistant
|
|
||||||
Destination: user
|
|
||||||
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}Source: system
|
{{ if .System }}Source: system
|
||||||
|
|
||||||
{{ .System }} <step> {{ end }}Source: user
|
{{ .System }} <step> {{ end }}Source: user
|
||||||
|
|
||||||
{{ .Prompt }} <step> Source: assistant
|
{{ .Prompt }} <step> Source: assistant
|
||||||
|
{{- if not .Response }}
|
||||||
Destination: user
|
Destination: user
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
{{ .Response }} <step>
|
{{ .Response }} <step>
|
||||||
{{- end -}}
|
|
|
@ -1,15 +1,5 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}System: {{ .System }}
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}User:
|
|
||||||
{{ else if eq .Role "assistant" }}Falcon:
|
|
||||||
{{ end }}{{ .Content }}
|
|
||||||
{{ end }}Falcon:
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}System: {{ .System }}
|
{{ if .System }}System: {{ .System }}
|
||||||
{{ end }}{{ if .Prompt }}User:
|
{{ end }}{{ if .Prompt }}User:
|
||||||
{{ .Prompt }}
|
{{ .Prompt }}
|
||||||
{{ end }}Falcon:
|
{{ end }}Falcon:
|
||||||
{{ .Response }}
|
{{ .Response }}
|
||||||
{{ end -}}
|
|
|
@ -1,17 +1,5 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- range $index, $_ := .Messages }}<start_of_turn>
|
|
||||||
{{- if eq .Role "user" }}user
|
|
||||||
{{- if and $.System (eq $index 0) }}
|
|
||||||
{{ $.System }}
|
|
||||||
{{- end }}
|
|
||||||
{{- else if eq .Role "assistant" }}model
|
|
||||||
{{- end }}
|
|
||||||
{{ .Content }}<end_of_turn>
|
|
||||||
{{ end }}<start_of_turn>model
|
|
||||||
{{ else -}}
|
|
||||||
<start_of_turn>user
|
<start_of_turn>user
|
||||||
{{ if .System }}{{ .System }}
|
{{ if .System }}{{ .System }}
|
||||||
{{ end }}{{ .Prompt }}<end_of_turn>
|
{{ end }}{{ .Prompt }}<end_of_turn>
|
||||||
<start_of_turn>model
|
<start_of_turn>model
|
||||||
{{ .Response }}<end_of_turn>
|
{{ .Response }}<end_of_turn>
|
||||||
{{ end -}}
|
|
|
@ -1,16 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}System:
|
|
||||||
{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}Question:
|
|
||||||
{{- else if eq .Role "assistant" }}Answer:
|
|
||||||
{{- end }}
|
|
||||||
{{ .Content }}
|
|
||||||
|
|
||||||
{{ end }}Answer:
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}System:
|
{{ if .System }}System:
|
||||||
{{ .System }}
|
{{ .System }}
|
||||||
|
|
||||||
|
@ -20,4 +7,3 @@
|
||||||
{{ end }}Answer:
|
{{ end }}Answer:
|
||||||
{{ .Response }}
|
{{ .Response }}
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -1,16 +1,6 @@
|
||||||
{{- if .Messages }}
|
[INST] <<SYS>>
|
||||||
{{- range $index, $_ := .Messages }}
|
{{- if .System }}
|
||||||
{{- if eq .Role "user" }}[INST] {{ if eq $index 0 }}<<SYS>>
|
{{ .System }}
|
||||||
{{- if $.System }}
|
|
||||||
{{ $.System }}
|
|
||||||
{{ end }}<</SYS>>
|
{{ end }}<</SYS>>
|
||||||
|
|
||||||
{{ end }}{{ .Content }}
|
{{ .Prompt }} [/INST] {{ .Response }}</s><s>
|
||||||
{{- else }} [/INST] {{ .Content }}</s><s>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }} [/INST]
|
|
||||||
{{- else -}}
|
|
||||||
[INST] <<SYS>>{{ if .System }}{{ .System }}{{ end }}<</SYS>>
|
|
||||||
|
|
||||||
{{ .Prompt }} [/INST] {{ .Response }}</s>
|
|
||||||
{{- end -}}
|
|
|
@ -1,14 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}<|start_header_id|>system<|end_header_id|>
|
|
||||||
|
|
||||||
{{ .System }}<|eot_id|>
|
|
||||||
{{- end }}
|
|
||||||
{{- range .Messages }}<|start_header_id|>{{ .Role }}<|end_header_id|>
|
|
||||||
|
|
||||||
{{ .Content }}<|eot_id|>
|
|
||||||
{{- end }}<|start_header_id|>assistant<|end_header_id|>
|
|
||||||
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}<|start_header_id|>system<|end_header_id|>
|
{{ if .System }}<|start_header_id|>system<|end_header_id|>
|
||||||
|
|
||||||
{{ .System }}<|eot_id|>{{ end }}{{ if .Prompt }}<|start_header_id|>user<|end_header_id|>
|
{{ .System }}<|eot_id|>{{ end }}{{ if .Prompt }}<|start_header_id|>user<|end_header_id|>
|
||||||
|
@ -16,4 +5,3 @@
|
||||||
{{ .Prompt }}<|eot_id|>{{ end }}<|start_header_id|>assistant<|end_header_id|>
|
{{ .Prompt }}<|eot_id|>{{ end }}<|start_header_id|>assistant<|end_header_id|>
|
||||||
|
|
||||||
{{ .Response }}<|eot_id|>
|
{{ .Response }}<|eot_id|>
|
||||||
{{- end -}}
|
|
|
@ -1,15 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}@@ Instruction
|
|
||||||
{{- else if eq .Role "assistant" }}@@ Response
|
|
||||||
{{- end }}
|
|
||||||
{{ .Content }}
|
|
||||||
|
|
||||||
{{ end }}@@ Response
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}{{ .System }}
|
{{ if .System }}{{ .System }}
|
||||||
|
|
||||||
{{ end }}{{ if .Prompt }}@@ Instruction
|
{{ end }}{{ if .Prompt }}@@ Instruction
|
||||||
|
@ -18,4 +6,3 @@
|
||||||
{{ end }}@@ Response
|
{{ end }}@@ Response
|
||||||
{{ .Response }}
|
{{ .Response }}
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -1,10 +1,3 @@
|
||||||
{{- if .Messages }}
|
[INST] {{ if .System }}{{ .System }}
|
||||||
{{- range $index, $_ := .Messages }}
|
|
||||||
{{- if eq .Role "user" }}[INST] {{ if and $.System (eq (len (slice $.Messages $index)) 1) }}{{ $.System }}
|
{{ end }}{{ .Prompt }}[/INST] {{ .Response }}</s>
|
||||||
{{ end }}{{ .Content }}
|
|
||||||
{{- else if eq .Role "assistant" }}[/INST] {{ .Content }}</s>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}[/INST]
|
|
||||||
{{- else -}}
|
|
||||||
[INST] {{ if .System }}{{ .System }} {{ end }}{{ .Prompt }}[/INST] {{ .Response }}</s>
|
|
||||||
{{- end -}}
|
|
|
@ -1,11 +1 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}GPT4 Correct System: {{ .System }}<|end_of_turn|>
|
|
||||||
{{- end }}
|
|
||||||
{{- range .Messages }}GPT4 Correct
|
|
||||||
{{- if eq .Role "user" }} User:
|
|
||||||
{{- else if eq .Role "assistant" }} Assistant:
|
|
||||||
{{- end }} {{ .Content }}<|end_of_turn|>
|
|
||||||
{{- end }}GPT4 Correct Assistant:
|
|
||||||
{{- else -}}
|
|
||||||
{{ if .System }}GPT4 Correct System: {{ .System }}<|end_of_turn|>{{ end }}GPT4 Correct User: {{ .Prompt }}<|end_of_turn|>GPT4 Correct Assistant: {{ .Response }}<|end_of_turn|>
|
{{ if .System }}GPT4 Correct System: {{ .System }}<|end_of_turn|>{{ end }}GPT4 Correct User: {{ .Prompt }}<|end_of_turn|>GPT4 Correct Assistant: {{ .Response }}<|end_of_turn|>
|
||||||
{{- end -}}
|
|
|
@ -1,15 +1,6 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}<|system|>
|
|
||||||
{{ .System }}<|end|>
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}<|{{ .Role }}|>
|
|
||||||
{{ .Content }}<|end|>
|
|
||||||
{{ end }}<|assistant|>
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}<|system|>
|
{{ if .System }}<|system|>
|
||||||
{{ .System }}<|end|>
|
{{ .System }}<|end|>
|
||||||
{{ end }}{{ if .Prompt }}<|user|>
|
{{ end }}{{ if .Prompt }}<|user|>
|
||||||
{{ .Prompt }}<|end|>
|
{{ .Prompt }}<|end|>
|
||||||
{{ end }}<|assistant|>
|
{{ end }}<|assistant|>
|
||||||
{{ .Response }}<|end|>
|
{{ .Response }}<|end|>
|
||||||
{{ end -}}
|
|
|
@ -1,16 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}### System:
|
|
||||||
{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}### User:
|
|
||||||
{{ .Content }}
|
|
||||||
{{ else if eq .Role "assistant" }}### Assistant:
|
|
||||||
{{ .Content }}</s>
|
|
||||||
{{ end }}
|
|
||||||
{{ end }}### Assistant:
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}### System:
|
{{ if .System }}### System:
|
||||||
{{ .System }}
|
{{ .System }}
|
||||||
|
|
||||||
|
@ -20,4 +7,3 @@
|
||||||
{{ end }}### Assistant:
|
{{ end }}### Assistant:
|
||||||
{{ .Response }}</s>
|
{{ .Response }}</s>
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -1,17 +1,3 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}### Instruction
|
|
||||||
{{ .Content }}
|
|
||||||
|
|
||||||
{{ else if eq .Role "assistant" }}### Response
|
|
||||||
{{ .Content }}<|endoftext|>
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- end }}### Response
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}{{ .System }}
|
{{ if .System }}{{ .System }}
|
||||||
|
|
||||||
{{ end }}{{ if .Prompt }}### Instruction
|
{{ end }}{{ if .Prompt }}### Instruction
|
||||||
|
@ -20,4 +6,3 @@
|
||||||
{{ end }}### Response
|
{{ end }}### Response
|
||||||
{{ .Response }}<|endoftext|>
|
{{ .Response }}<|endoftext|>
|
||||||
|
|
||||||
{{ end -}}
|
|
|
@ -102,8 +102,22 @@ var response = parse.ActionNode{
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var funcs = template.FuncMap{
|
||||||
|
// contents returns the contents of messages with an optional role filter
|
||||||
|
"contents": func(v []*api.Message, role ...string) string {
|
||||||
|
var parts []string
|
||||||
|
for _, m := range v {
|
||||||
|
if len(role) == 0 || role[0] == "" || m.Role == role[0] {
|
||||||
|
parts = append(parts, m.Content)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return strings.Join(parts, "\n\n")
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
func Parse(s string) (*Template, error) {
|
func Parse(s string) (*Template, error) {
|
||||||
tmpl := template.New("").Option("missingkey=zero")
|
tmpl := template.New("").Option("missingkey=zero").Funcs(funcs)
|
||||||
|
|
||||||
tmpl, err := tmpl.Parse(s)
|
tmpl, err := tmpl.Parse(s)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -149,23 +163,21 @@ type Values struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Template) Execute(w io.Writer, v Values) error {
|
func (t *Template) Execute(w io.Writer, v Values) error {
|
||||||
system, collated := collate(v.Messages)
|
collated := collate(v.Messages)
|
||||||
if !v.forceLegacy && slices.Contains(t.Vars(), "messages") {
|
if !v.forceLegacy && slices.Contains(t.Vars(), "messages") {
|
||||||
return t.Template.Execute(w, map[string]any{
|
return t.Template.Execute(w, map[string]any{
|
||||||
"System": system,
|
|
||||||
"Messages": collated,
|
"Messages": collated,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
var b bytes.Buffer
|
var b bytes.Buffer
|
||||||
var prompt, response string
|
var system, prompt, response string
|
||||||
for i, m := range collated {
|
for i, m := range collated {
|
||||||
switch m.Role {
|
switch m.Role {
|
||||||
|
case "system":
|
||||||
|
system = m.Content
|
||||||
case "user":
|
case "user":
|
||||||
prompt = m.Content
|
prompt = m.Content
|
||||||
if i != 0 {
|
|
||||||
system = ""
|
|
||||||
}
|
|
||||||
case "assistant":
|
case "assistant":
|
||||||
response = m.Content
|
response = m.Content
|
||||||
}
|
}
|
||||||
|
@ -179,6 +191,7 @@ func (t *Template) Execute(w io.Writer, v Values) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
system = ""
|
||||||
prompt = ""
|
prompt = ""
|
||||||
response = ""
|
response = ""
|
||||||
}
|
}
|
||||||
|
@ -209,25 +222,14 @@ func (t *Template) Execute(w io.Writer, v Values) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
type messages []*api.Message
|
|
||||||
|
|
||||||
// collate messages based on role. consecutive messages of the same role are merged
|
// collate messages based on role. consecutive messages of the same role are merged
|
||||||
// into a single message. collate also pulls out and merges messages with Role == "system"
|
// into a single message. collate also pulls out and merges messages with Role == "system"
|
||||||
// which are templated separately. As a side effect, it mangles message content adding image
|
// which are templated separately. As a side effect, it mangles message content adding image
|
||||||
// tags ([img-%d]) as needed
|
// tags ([img-%d]) as needed
|
||||||
func collate(msgs []api.Message) (system string, collated messages) {
|
func collate(msgs []api.Message) (collated []*api.Message) {
|
||||||
var n int
|
var n int
|
||||||
for i := range msgs {
|
for i := range msgs {
|
||||||
msg := msgs[i]
|
msg := msgs[i]
|
||||||
if msg.Role == "system" {
|
|
||||||
if system != "" {
|
|
||||||
system += "\n\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
system += msg.Content
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
for range msg.Images {
|
for range msg.Images {
|
||||||
imageTag := fmt.Sprintf("[img-%d]", n)
|
imageTag := fmt.Sprintf("[img-%d]", n)
|
||||||
if !strings.Contains(msg.Content, "[img]") {
|
if !strings.Contains(msg.Content, "[img]") {
|
||||||
|
|
|
@ -116,12 +116,20 @@ func TestTemplate(t *testing.T) {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if diff := cmp.Diff(actual.Bytes(), expect); diff != "" {
|
bts := actual.Bytes()
|
||||||
|
|
||||||
|
if slices.Contains([]string{"chatqa.gotmpl", "llama2-chat.gotmpl", "mistral-instruct.gotmpl", "openchat.gotmpl", "vicuna.gotmpl"}, match) && bts[len(bts)-1] == ' ' {
|
||||||
|
t.Log("removing trailing space from output")
|
||||||
|
bts = bts[:len(bts)-1]
|
||||||
|
}
|
||||||
|
|
||||||
|
if diff := cmp.Diff(bts, expect); diff != "" {
|
||||||
t.Errorf("mismatch (-got +want):\n%s", diff)
|
t.Errorf("mismatch (-got +want):\n%s", diff)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("legacy", func(t *testing.T) {
|
t.Run("legacy", func(t *testing.T) {
|
||||||
|
t.Skip("legacy outputs are currently default outputs")
|
||||||
var legacy bytes.Buffer
|
var legacy bytes.Buffer
|
||||||
if err := tmpl.Execute(&legacy, Values{Messages: tt, forceLegacy: true}); err != nil {
|
if err := tmpl.Execute(&legacy, Values{Messages: tt, forceLegacy: true}); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
|
@ -154,11 +162,13 @@ func TestParse(t *testing.T) {
|
||||||
{"{{ .System }} {{ .Prompt }} {{ .Response }}", []string{"prompt", "response", "system"}},
|
{"{{ .System }} {{ .Prompt }} {{ .Response }}", []string{"prompt", "response", "system"}},
|
||||||
{"{{ with .Tools }}{{ . }}{{ end }} {{ .System }} {{ .Prompt }}", []string{"prompt", "response", "system", "tools"}},
|
{"{{ with .Tools }}{{ . }}{{ end }} {{ .System }} {{ .Prompt }}", []string{"prompt", "response", "system", "tools"}},
|
||||||
{"{{ range .Messages }}{{ .Role }} {{ .Content }}{{ end }}", []string{"content", "messages", "role"}},
|
{"{{ range .Messages }}{{ .Role }} {{ .Content }}{{ end }}", []string{"content", "messages", "role"}},
|
||||||
{"{{ range .Messages }}{{ if eq .Role \"system\" }}SYSTEM: {{ .Content }}{{ else if eq .Role \"user\" }}USER: {{ .Content }}{{ else if eq .Role \"assistant\" }}ASSISTANT: {{ .Content }}{{ end }}{{ end }}", []string{"content", "messages", "role"}},
|
{`{{- range .Messages }}
|
||||||
|
{{- if eq .Role "system" }}SYSTEM:
|
||||||
|
{{- else if eq .Role "user" }}USER:
|
||||||
|
{{- else if eq .Role "assistant" }}ASSISTANT:
|
||||||
|
{{- end }} {{ .Content }}
|
||||||
|
{{- end }}`, []string{"content", "messages", "role"}},
|
||||||
{`{{- if .Messages }}
|
{`{{- if .Messages }}
|
||||||
{{- if .System }}<|im_start|>system
|
|
||||||
{{ .System }}<|im_end|>
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}<|im_start|>{{ .Role }}
|
{{- range .Messages }}<|im_start|>{{ .Role }}
|
||||||
{{ .Content }}<|im_end|>
|
{{ .Content }}<|im_end|>
|
||||||
{{ end }}<|im_start|>assistant
|
{{ end }}<|im_start|>assistant
|
||||||
|
@ -200,11 +210,18 @@ func TestExecuteWithMessages(t *testing.T) {
|
||||||
{
|
{
|
||||||
"mistral",
|
"mistral",
|
||||||
[]template{
|
[]template{
|
||||||
{"no response", `[INST] {{ if .System }}{{ .System }}{{ "\n\n" }}{{ end }}{{ .Prompt }}[/INST] `},
|
{"no response", `[INST] {{ if .System }}{{ .System }}
|
||||||
{"response", `[INST] {{ if .System }}{{ .System }}{{ "\n\n" }}{{ end }}{{ .Prompt }}[/INST] {{ .Response }}`},
|
|
||||||
{"messages", `{{- range $index, $_ := .Messages }}
|
{{ end }}{{ .Prompt }}[/INST] `},
|
||||||
{{- if eq .Role "user" }}[INST] {{ if and (eq $index 0) $.System }}{{ $.System }}{{ "\n\n" }}
|
{"response", `[INST] {{ if .System }}{{ .System }}
|
||||||
{{- end }}{{ .Content }}[/INST] {{ else if eq .Role "assistant" }}{{ .Content }}
|
|
||||||
|
{{ end }}{{ .Prompt }}[/INST] {{ .Response }}`},
|
||||||
|
{"messages", `{{- $system := contents .Messages "system" -}}
|
||||||
|
{{- range $index, $_ := .Messages }}
|
||||||
|
{{- if eq .Role "user" }}[INST] {{ if $system }}{{ $system }}
|
||||||
|
{{- $system = "" }}
|
||||||
|
|
||||||
|
{{ end }}{{ .Content }}[/INST] {{ else if eq .Role "assistant" }}{{ .Content }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}`},
|
{{- end }}`},
|
||||||
},
|
},
|
||||||
|
@ -220,12 +237,18 @@ func TestExecuteWithMessages(t *testing.T) {
|
||||||
{
|
{
|
||||||
"mistral system",
|
"mistral system",
|
||||||
[]template{
|
[]template{
|
||||||
{"no response", `[INST] {{ if .System }}{{ .System }}{{ "\n\n" }}{{ end }}{{ .Prompt }}[/INST] `},
|
{"no response", `[INST] {{ if .System }}{{ .System }}
|
||||||
{"response", `[INST] {{ if .System }}{{ .System }}{{ "\n\n" }}{{ end }}{{ .Prompt }}[/INST] {{ .Response }}`},
|
|
||||||
{"messages", `
|
{{ end }}{{ .Prompt }}[/INST] `},
|
||||||
|
{"response", `[INST] {{ if .System }}{{ .System }}
|
||||||
|
|
||||||
|
{{ end }}{{ .Prompt }}[/INST] {{ .Response }}`},
|
||||||
|
{"messages", `{{- $system := contents .Messages "system" -}}
|
||||||
{{- range $index, $_ := .Messages }}
|
{{- range $index, $_ := .Messages }}
|
||||||
{{- if eq .Role "user" }}[INST] {{ if and (eq $index 0) $.System }}{{ $.System }}{{ "\n\n" }}
|
{{- if eq .Role "user" }}[INST] {{ if $system }}{{ $system }}
|
||||||
{{- end }}{{ .Content }}[/INST] {{ else if eq .Role "assistant" }}{{ .Content }}
|
{{- $system = "" }}
|
||||||
|
|
||||||
|
{{ end }}{{ .Content }}[/INST] {{ else if eq .Role "assistant" }}{{ .Content }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}`},
|
{{- end }}`},
|
||||||
},
|
},
|
||||||
|
@ -253,12 +276,9 @@ Hello friend![/INST] Hello human![INST] What is your name?[/INST] `,
|
||||||
{{ .Response }}<|im_end|>
|
{{ .Response }}<|im_end|>
|
||||||
`},
|
`},
|
||||||
{"messages", `
|
{"messages", `
|
||||||
{{- range $index, $_ := .Messages }}
|
{{- range $index, $_ := .Messages }}<|im_start|>{{ .Role }}
|
||||||
{{- if and (eq .Role "user") (eq $index 0) $.System }}<|im_start|>system
|
{{ .Content }}<|im_end|>
|
||||||
{{ $.System }}<|im_end|>{{ "\n" }}
|
{{ end }}<|im_start|>assistant
|
||||||
{{- end }}<|im_start|>{{ .Role }}
|
|
||||||
{{ .Content }}<|im_end|>{{ "\n" }}
|
|
||||||
{{- end }}<|im_start|>assistant
|
|
||||||
`},
|
`},
|
||||||
},
|
},
|
||||||
Values{
|
Values{
|
||||||
|
@ -291,9 +311,11 @@ What is your name?<|im_end|>
|
||||||
`},
|
`},
|
||||||
{"messages", `
|
{"messages", `
|
||||||
{{- range .Messages }}
|
{{- range .Messages }}
|
||||||
{{- if eq .Role "user" }}Question: {{ .Content }}{{ "\n\n" }}
|
{{- if eq .Role "user" }}Question: {{ .Content }}
|
||||||
{{- else if eq .Role "assistant" }}Answer: {{ .Content }}{{ "\n\n" }}
|
|
||||||
{{- end }}
|
{{ else if eq .Role "assistant" }}Answer: {{ .Content }}
|
||||||
|
|
||||||
|
{{ end }}
|
||||||
{{- end }}Answer: `},
|
{{- end }}Answer: `},
|
||||||
},
|
},
|
||||||
Values{
|
Values{
|
||||||
|
@ -341,3 +363,36 @@ Answer: `,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestFuncs(t *testing.T) {
|
||||||
|
t.Run("contents", func(t *testing.T) {
|
||||||
|
cases := map[string]string{
|
||||||
|
"": "A\n\nB\n\nC\n\nD\n\nE\n\nF",
|
||||||
|
"system": "A\n\nF",
|
||||||
|
"user": "B\n\nE",
|
||||||
|
"assistant": "C\n\nD",
|
||||||
|
}
|
||||||
|
|
||||||
|
s := []*api.Message{
|
||||||
|
{Role: "system", Content: "A"},
|
||||||
|
{Role: "user", Content: "B"},
|
||||||
|
{Role: "assistant", Content: "C"},
|
||||||
|
{Role: "assistant", Content: "D"},
|
||||||
|
{Role: "user", Content: "E"},
|
||||||
|
{Role: "system", Content: "F"},
|
||||||
|
}
|
||||||
|
|
||||||
|
fn, ok := funcs["contents"].(func([]*api.Message, ...string) string)
|
||||||
|
if !ok {
|
||||||
|
t.Fatal("contents is not a function")
|
||||||
|
}
|
||||||
|
|
||||||
|
for k, v := range cases {
|
||||||
|
t.Run(k, func(t *testing.T) {
|
||||||
|
if diff := cmp.Diff(fn(s, k), v); diff != "" {
|
||||||
|
t.Errorf("mismatch (-got +want):\n%s", diff)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
|
@ -2,4 +2,6 @@
|
||||||
You are a helpful assistant.
|
You are a helpful assistant.
|
||||||
<</SYS>>
|
<</SYS>>
|
||||||
|
|
||||||
Hello, how are you? [/INST] I'm doing great. How can I help you today?</s><s>[INST] I'd like to show off how chat templating works! [/INST]
|
Hello, how are you? [/INST] I'm doing great. How can I help you today?</s><s>[INST] <<SYS>><</SYS>>
|
||||||
|
|
||||||
|
I'd like to show off how chat templating works! [/INST]
|
|
@ -1,3 +1,5 @@
|
||||||
[INST] <<SYS>><</SYS>>
|
[INST] <<SYS>><</SYS>>
|
||||||
|
|
||||||
Hello, how are you? [/INST] I'm doing great. How can I help you today?</s><s>[INST] I'd like to show off how chat templating works! [/INST]
|
Hello, how are you? [/INST] I'm doing great. How can I help you today?</s><s>[INST] <<SYS>><</SYS>>
|
||||||
|
|
||||||
|
I'd like to show off how chat templating works! [/INST]
|
|
@ -1,2 +1,3 @@
|
||||||
[INST] Hello, how are you?[/INST] I'm doing great. How can I help you today?</s>[INST] You are a helpful assistant.
|
[INST] You are a helpful assistant.
|
||||||
I'd like to show off how chat templating works![/INST]
|
|
||||||
|
Hello, how are you?[/INST] I'm doing great. How can I help you today?</s>[INST] I'd like to show off how chat templating works![/INST]
|
|
@ -1,15 +1,4 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}{{ .System }}
|
|
||||||
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}
|
|
||||||
{{- if eq .Role "user" }}USER: {{ .Content }}
|
|
||||||
{{ else if eq .Role "assistant" }}ASSISTANT: {{ .Content }}</s>
|
|
||||||
{{ end }}
|
|
||||||
{{- end }}ASSISTANT:
|
|
||||||
{{- else -}}
|
|
||||||
{{ if .System }}{{ .System }}
|
{{ if .System }}{{ .System }}
|
||||||
|
|
||||||
{{ end }}{{ if .Prompt }}USER: {{ .Prompt }}
|
{{ end }}{{ if .Prompt }}USER: {{ .Prompt }}
|
||||||
{{ end }}ASSISTANT: {{ .Response }}</s>
|
{{ end }}ASSISTANT: {{ .Response }}</s>
|
||||||
{{ end -}}
|
|
|
@ -1,15 +1,6 @@
|
||||||
{{- if .Messages }}
|
|
||||||
{{- if .System }}<|system|>
|
|
||||||
{{ .System }}</s>
|
|
||||||
{{ end }}
|
|
||||||
{{- range .Messages }}<|{{ .Role }}|>
|
|
||||||
{{ .Content }}</s>
|
|
||||||
{{ end }}<|assistant|>
|
|
||||||
{{ else -}}
|
|
||||||
{{ if .System }}<|system|>
|
{{ if .System }}<|system|>
|
||||||
{{ .System }}</s>
|
{{ .System }}</s>
|
||||||
{{ end }}{{ if .Prompt }}<|user|>
|
{{ end }}{{ if .Prompt }}<|user|>
|
||||||
{{ .Prompt }}</s>
|
{{ .Prompt }}</s>
|
||||||
{{ end }}<|assistant|>
|
{{ end }}<|assistant|>
|
||||||
{{ .Response }}</s>
|
{{ .Response }}</s>
|
||||||
{{ end -}}
|
|
Loading…
Reference in a new issue