-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathembedding_test.go
74 lines (71 loc) · 1.52 KB
/
embedding_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package gollama
import (
"context"
"testing"
)
func TestGollama_Embedding(t *testing.T) {
type args struct {
Prompt string
}
tests := []struct {
name string
c *Gollama
args args
wantLen int
wantErr bool
}{
{
name: "Embedding",
c: New("llama3.2"),
args: args{Prompt: "hello"},
wantLen: 3072,
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := tt.c.Embedding(context.Background(), tt.args.Prompt)
if (err != nil) != tt.wantErr {
t.Errorf("Gollama.Embedding() error = %v, wantErr %v", err, tt.wantErr)
return
}
if len(got) != tt.wantLen {
t.Errorf("Gollama.Embedding() = %v, want %v", len(got), tt.wantLen)
}
})
}
}
func TestCosenoSimilarity(t *testing.T) {
type args struct {
vector1 []float64
vector2 []float64
}
tests := []struct {
name string
args args
want float64
}{
{
name: "CosenoSimilarity",
args: args{vector1: []float64{1, 2, 3}, vector2: []float64{4, 5, 6}},
want: 0.9746318461970762,
},
{
name: "CosenoSimilarity",
args: args{vector1: []float64{1, 1, 1}, vector2: []float64{1, 1, 1}},
want: 1.0000000000000002,
},
{
name: "CosenoSimilarity",
args: args{vector1: []float64{1, 0, 0}, vector2: []float64{0, 1, 0}},
want: 0.0,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := CosenoSimilarity(tt.args.vector1, tt.args.vector2); got != tt.want {
t.Errorf("CosenoSimilarity() = %v, want %v", got, tt.want)
}
})
}
}