Skip to content

Commit

Permalink
Add Go API for Kokoro TTS 1.0 (#1804)
Browse files Browse the repository at this point in the history
  • Loading branch information
csukuangfj authored Feb 7, 2025
1 parent e2e0f25 commit e1a88a7
Show file tree
Hide file tree
Showing 6 changed files with 44 additions and 0 deletions.
5 changes: 5 additions & 0 deletions .github/workflows/test-go-package.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,11 @@ jobs:
go build
ls -lh
echo "Test kokoro zh+en"
./run-kokoro-zh-en.sh
rm -rf kokoro-multi-*
ls -lh
echo "Test kokoro en"
./run-kokoro-en.sh
rm -rf kokoro-en-*
Expand Down
5 changes: 5 additions & 0 deletions .github/workflows/test-go.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,11 @@ jobs:
go build
ls -lh
echo "Test kokoro zh+en"
./run-kokoro-zh-en.sh
rm -rf kokoro-multi-*
ls -lh
echo "Test kokoro en"
./run-kokoro-en.sh
rm -rf kokoro-en-*
Expand Down
2 changes: 2 additions & 0 deletions go-api-examples/non-streaming-tts/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ func main() {
flag.StringVar(&config.Model.Kokoro.Voices, "kokoro-voices", "", "Path to voices.bin for Kokoro")
flag.StringVar(&config.Model.Kokoro.Tokens, "kokoro-tokens", "", "Path to tokens.txt for Kokoro")
flag.StringVar(&config.Model.Kokoro.DataDir, "kokoro-data-dir", "", "Path to espeak-ng-data for Kokoro")
flag.StringVar(&config.Model.Kokoro.DictDir, "kokoro-dict-dir", "", "Path to dict for Kokoro")
flag.StringVar(&config.Model.Kokoro.Lexicon, "kokoro-lexicon", "", "Path to lexicon files for Kokoro")
flag.Float32Var(&config.Model.Kokoro.LengthScale, "kokoro-length-scale", 1.0, "length_scale for Kokoro. small -> faster in speech speed; large -> slower")

flag.IntVar(&config.Model.NumThreads, "num-threads", 1, "Number of threads for computing")
Expand Down
23 changes: 23 additions & 0 deletions go-api-examples/non-streaming-tts/run-kokoro-zh-en.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/usr/bin/env bash

set -ex

if [ ! -f ./kokoro-multi-lang-v1_0/model.onnx ]; then
curl -SL -O https://github.com/k2-fsa/sherpa-onnx/releases/download/tts-models/kokoro-multi-lang-v1_0.tar.bz2
tar xf kokoro-multi-lang-v1_0.tar.bz2
rm kokoro-multi-lang-v1_0.tar.bz2
fi

go mod tidy
go build

./non-streaming-tts \
--kokoro-model=./kokoro-multi-lang-v1_0/model.onnx \
--kokoro-voices=./kokoro-multi-lang-v1_0/voices.bin \
--kokoro-tokens=./kokoro-multi-lang-v1_0/tokens.txt \
--kokoro-data-dir=./kokoro-multi-lang-v1_0/espeak-ng-data \
--kokoro-dict-dir=./kokoro-multi-lang-v1_0/dict \
--kokoro-lexicon=./kokoro-multi-lang-v1_0/lexicon-us-en.txt,./kokoro-multi-lang-v1_0/lexicon-zh.txt \
--debug=1 \
--output-filename=./test-kokoro-zh-en.wav \
"中英文语音合成测试。This is generated by next generation Kaldi using Kokoro without Misaki. 你觉得中英文说的如何呢?"
1 change: 1 addition & 0 deletions scripts/go/_internal/non-streaming-tts/run-kokoro-zh-en.sh
8 changes: 8 additions & 0 deletions scripts/go/sherpa_onnx.go
Original file line number Diff line number Diff line change
Expand Up @@ -687,6 +687,8 @@ type OfflineTtsKokoroModelConfig struct {
Voices string // Path to the voices.bin for kokoro
Tokens string // Path to tokens.txt
DataDir string // Path to espeak-ng-data directory
DictDir string // Path to dict directory
Lexicon string // Path to lexicon files
LengthScale float32 // Please use 1.0 in general. Smaller -> Faster speech speed. Larger -> Slower speech speed
}

Expand Down Expand Up @@ -798,6 +800,12 @@ func NewOfflineTts(config *OfflineTtsConfig) *OfflineTts {
c.model.kokoro.data_dir = C.CString(config.Model.Kokoro.DataDir)
defer C.free(unsafe.Pointer(c.model.kokoro.data_dir))

c.model.kokoro.dict_dir = C.CString(config.Model.Kokoro.DictDir)
defer C.free(unsafe.Pointer(c.model.kokoro.dict_dir))

c.model.kokoro.lexicon = C.CString(config.Model.Kokoro.Lexicon)
defer C.free(unsafe.Pointer(c.model.kokoro.lexicon))

c.model.kokoro.length_scale = C.float(config.Model.Kokoro.LengthScale)

c.model.num_threads = C.int(config.Model.NumThreads)
Expand Down

0 comments on commit e1a88a7

Please sign in to comment.