RWKV-Runner/backend-golang/rwkv.go

177 lines
5.0 KiB
Go
Raw Normal View History

2023-05-06 23:39:23 +08:00
package backend_golang
import (
"encoding/json"
2023-05-20 23:34:33 +08:00
"errors"
"os"
2023-05-06 23:39:23 +08:00
"os/exec"
2023-05-27 14:40:59 +08:00
"runtime"
2023-05-17 11:39:00 +08:00
"strconv"
"strings"
2023-05-06 23:39:23 +08:00
)
2023-11-07 22:24:06 +08:00
func (a *App) StartServer(python string, port int, host string, webui bool, rwkvBeta bool) (string, error) {
2023-05-31 15:45:26 +08:00
var err error
if python == "" {
python, err = GetPython()
}
2023-05-17 11:39:00 +08:00
if err != nil {
return "", err
}
2023-08-14 22:07:15 +08:00
args := []string{python, "./backend-python/main.py"}
2023-11-07 22:24:06 +08:00
if webui {
args = append(args, "--webui")
}
2023-08-14 22:07:15 +08:00
if rwkvBeta {
args = append(args, "--rwkv-beta")
}
args = append(args, "--port", strconv.Itoa(port), "--host", host)
return Cmd(args...)
2023-05-20 23:34:33 +08:00
}
2023-08-16 23:07:58 +08:00
func (a *App) StartWebGPUServer(port int, host string) (string, error) {
args := []string{"./backend-rust/webgpu_server"}
args = append(args, "--port", strconv.Itoa(port), "--ip", host)
2023-08-16 23:07:58 +08:00
return Cmd(args...)
}
2023-05-31 15:45:26 +08:00
func (a *App) ConvertModel(python string, modelPath string, strategy string, outPath string) (string, error) {
var err error
if python == "" {
python, err = GetPython()
}
2023-05-06 23:39:23 +08:00
if err != nil {
2023-05-13 20:15:18 +08:00
return "", err
2023-05-06 23:39:23 +08:00
}
2023-06-02 22:20:57 +08:00
return Cmd(python, "./backend-python/convert_model.py", "--in", modelPath, "--out", outPath, "--strategy", strategy)
2023-05-06 23:39:23 +08:00
}
2023-05-17 21:20:41 +08:00
func (a *App) ConvertSafetensors(modelPath string, outPath string) (string, error) {
args := []string{"./backend-rust/web-rwkv-converter"}
args = append(args, "--input", modelPath, "--output", outPath)
return Cmd(args...)
2023-08-16 23:07:58 +08:00
}
2023-07-03 17:41:47 +08:00
func (a *App) ConvertData(python string, input string, outputPrefix string, vocab string) (string, error) {
var err error
if python == "" {
python, err = GetPython()
}
if err != nil {
return "", err
}
tokenizerType := "HFTokenizer"
if strings.Contains(vocab, "rwkv_vocab_v20230424") {
tokenizerType = "RWKVTokenizer"
}
input = strings.TrimSuffix(input, "/")
if fi, err := os.Stat(input); err == nil && fi.IsDir() {
files, err := os.ReadDir(input)
if err != nil {
return "", err
}
jsonlFile, err := os.Create(outputPrefix + ".jsonl")
if err != nil {
return "", err
}
defer jsonlFile.Close()
for _, file := range files {
if file.IsDir() || !strings.HasSuffix(file.Name(), ".txt") {
continue
}
textContent, err := os.ReadFile(input + "/" + file.Name())
if err != nil {
return "", err
}
2023-07-11 12:19:39 +08:00
textJson, err := json.Marshal(map[string]string{"text": strings.ReplaceAll(strings.ReplaceAll(string(textContent), "\r\n", "\n"), "\r", "\n")})
if err != nil {
return "", err
}
if _, err := jsonlFile.WriteString(string(textJson) + "\n"); err != nil {
return "", err
}
}
input = outputPrefix + ".jsonl"
} else if err != nil {
return "", err
}
2023-07-03 17:41:47 +08:00
return Cmd(python, "./finetune/json2binidx_tool/tools/preprocess_data.py", "--input", input, "--output-prefix", outputPrefix, "--vocab", vocab,
"--tokenizer-type", tokenizerType, "--dataset-impl", "mmap", "--append-eod")
}
func (a *App) MergeLora(python string, useGpu bool, loraAlpha int, baseModel string, loraPath string, outputPath string) (string, error) {
var err error
if python == "" {
python, err = GetPython()
}
if err != nil {
return "", err
}
args := []string{python, "./finetune/lora/merge_lora.py"}
if useGpu {
args = append(args, "--use-gpu")
}
args = append(args, strconv.Itoa(loraAlpha), baseModel, loraPath, outputPath)
return Cmd(args...)
}
2023-05-31 15:45:26 +08:00
func (a *App) DepCheck(python string) error {
var err error
if python == "" {
python, err = GetPython()
}
2023-05-20 23:34:33 +08:00
if err != nil {
return err
}
2023-06-01 16:54:21 +08:00
out, err := exec.Command(python, a.exDir+"./backend-python/dep_check.py").CombinedOutput()
2023-05-20 23:34:33 +08:00
if err != nil {
return errors.New("DepCheck Error: " + string(out))
}
return nil
2023-05-17 23:27:52 +08:00
}
2023-05-31 15:45:26 +08:00
func (a *App) InstallPyDep(python string, cnMirror bool) (string, error) {
var err error
if python == "" {
python, err = GetPython()
if runtime.GOOS == "windows" {
python = `"%CD%/` + python + `"`
}
2023-05-31 15:45:26 +08:00
}
2023-05-20 23:34:33 +08:00
if err != nil {
return "", err
}
2023-05-27 14:40:59 +08:00
if runtime.GOOS == "windows" {
ChangeFileLine("./py310/python310._pth", 3, "Lib\\site-packages")
2023-10-25 17:51:59 +08:00
installScript := python + " ./backend-python/get-pip.py -i https://pypi.tuna.tsinghua.edu.cn/simple --no-warn-script-location\n" +
2023-10-25 17:08:50 +08:00
python + " -m pip install torch==1.13.1 torchvision==0.14.1 torchaudio==0.13.1 --index-url https://download.pytorch.org/whl/cu117 --no-warn-script-location\n" +
python + " -m pip install -r ./backend-python/requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple --no-warn-script-location\n" +
"exit"
if !cnMirror {
installScript = strings.Replace(installScript, " -i https://pypi.tuna.tsinghua.edu.cn/simple", "", -1)
}
err = os.WriteFile("./install-py-dep.bat", []byte(installScript), 0644)
if err != nil {
return "", err
}
return Cmd("install-py-dep.bat")
2023-05-20 23:34:33 +08:00
}
if cnMirror {
return Cmd(python, "-m", "pip", "install", "-r", "./backend-python/requirements_without_cyac.txt", "-i", "https://pypi.tuna.tsinghua.edu.cn/simple")
2023-05-21 10:49:45 +08:00
} else {
return Cmd(python, "-m", "pip", "install", "-r", "./backend-python/requirements_without_cyac.txt")
2023-05-21 10:49:45 +08:00
}
2023-05-17 21:20:41 +08:00
}
2023-07-07 20:16:35 +08:00
func (a *App) GetPyError() string {
content, err := os.ReadFile("./error.txt")
if err != nil {
return ""
}
return string(content)
}