This repository has been archived on 2025-08-26. You can view files and clone it, but cannot push or open issues or pull requests.
Files
enginex-mr_series-sherpa-onnx/nodejs-examples/test-offline-tts-vits-zh.js

40 lines
1.2 KiB
JavaScript
Raw Normal View History

2023-11-21 23:20:08 +08:00
// Copyright (c) 2023 Xiaomi Corporation (authors: Fangjun Kuang)
const sherpa_onnx = require('sherpa-onnx');
function createOfflineTts() {
2024-03-03 20:00:36 +08:00
let offlineTtsVitsModelConfig = {
model: './vits-icefall-zh-aishell3/model.onnx',
lexicon: './vits-icefall-zh-aishell3/lexicon.txt',
tokens: './vits-icefall-zh-aishell3/tokens.txt',
2024-03-03 20:00:36 +08:00
noiseScale: 0.667,
noiseScaleW: 0.8,
lengthScale: 1.0,
};
let offlineTtsModelConfig = {
offlineTtsVitsModelConfig: offlineTtsVitsModelConfig,
numThreads: 1,
debug: 1,
provider: 'cpu',
};
2023-11-21 23:20:08 +08:00
2024-03-03 20:00:36 +08:00
let offlineTtsConfig = {
offlineTtsModelConfig: offlineTtsModelConfig,
ruleFsts:
'./vits-icefall-zh-aishell3/phone.fst,./vits-icefall-zh-aishell3/date.fst,./vits-icefall-zh-aishell3/number.fst,./vits-icefall-zh-aishell3/new_heteronym.fst',
ruleFars: './vits-icefall-zh-aishell3/rule.far',
2024-03-03 20:00:36 +08:00
maxNumSentences: 1,
};
2023-11-21 23:20:08 +08:00
2024-03-03 20:00:36 +08:00
return sherpa_onnx.createOfflineTts(offlineTtsConfig);
2023-11-21 23:20:08 +08:00
}
const tts = createOfflineTts();
const speakerId = 66;
const speed = 1.0;
2024-03-03 20:00:36 +08:00
const audio = tts.generate(
{text: '3年前中国总人口是1411778724人', sid: speakerId, speed: speed});
tts.save('./test-vits-zh.wav', audio);
console.log('Saved to test-vits-zh.wav successfully.');
2023-11-21 23:20:08 +08:00
tts.free();