-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathtoken_num.go
89 lines (72 loc) · 1.93 KB
/
token_num.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package main
import (
"bufio"
"fmt"
"log"
"os"
"strings"
"github.com/pkoukk/tiktoken-go"
)
// main
func main() {
textList, modelList, encodingList := ReadTestFile()
testTokenByModel(textList, modelList)
fmt.Println("=========================================")
testTokenByEncoding(textList, encodingList)
}
// read all columns from a file
func ReadTestFile() (textList []string, modelList []string, encodingList []string) {
file, err := os.Open("test/test.txt")
if err != nil {
log.Fatal(err)
}
defer file.Close()
var lines []string
scanner := bufio.NewScanner(file)
for scanner.Scan() {
lines = append(lines, scanner.Text())
}
if err := scanner.Err(); err != nil {
log.Fatal(err)
}
textList = strings.Split(lines[0], ",")
modelList = strings.Split(lines[1], ",")
encodingList = strings.Split(lines[2], ",")
return
}
// getTokenByModel
func getTokenByModel(text string, model string) (num_tokens int) {
tkm, err := tiktoken.EncodingForModel(model)
if err != nil {
err = fmt.Errorf(": %v", err)
return
}
token := tkm.Encode(text, nil, nil)
return len(token)
}
// getTokenByEncoding
func getTokenByEncoding(text string, encoding string) (num_tokens int) {
tke, err := tiktoken.GetEncoding(encoding)
if err != nil {
err = fmt.Errorf(": %v", err)
return
}
token := tke.Encode(text, nil, nil)
return len(token)
}
// testTokenByModel
func testTokenByModel(textList []string, modelList []string) {
for i := 0; i < len(textList); i++ {
for j := 0; j < len(modelList); j++ {
fmt.Printf("text: %s, model: %s, token: %d\n", textList[i], modelList[j], getTokenByModel(textList[i], modelList[j]))
}
}
}
// testTokenByEncoding
func testTokenByEncoding(textList []string, encodingList []string) {
for i := 0; i < len(textList); i++ {
for j := 0; j < len(encodingList); j++ {
fmt.Printf("text: %s, encoding: %s, token: %d\n", textList[i], encodingList[j], getTokenByEncoding(textList[i], encodingList[j]))
}
}
}