这种:https://github.com/Winter-of-Cirno/MoeGoeONNX
其实我还优化了cleaners工程的布局(text
文件夹)但是还没传。
目前只支持symbols对应的数字转成wave. (原因事Cleaners没写)
其实Cleaners可以调用https://github.com/NaruseMioShirakana/JapaneseCleaner佬的DLL。但是这个库貌似目前只支持CjangCjengh佬的japanese_cleaners第一版。
这个项目当前处于非常不完善的阶段。大部分功能还没有实现。具体可以打开OnnxVitsDemo
工程进行一些查看。
以下的代码能简单地完成一个symbols-index到wav的转换。这里使用了MoeGoeONNX 项目进行Onnx转换(有可能不成功。因为我转换的时候遇到些bug顺手改了)。使用的是C佬的7人模型. 我的Demo代码在这
// Instantiate a OnnxVits Model by Calling 'new'
var model = new OnnxVitsLib.VitsModel(@"E:\ai\model\onnx_nene\Mods\Nene", modelPrefix:"Nene_", isMultiSpeaker:true);
// おはようございます经过japanese_cleaner之后的symbol对应index
var x = new Int64[] { 25,38,19,13,33,25,25,18,25,34,13,20,23,13,37,28,12,2 };
// hps.data.add_blank
var xin = add0(x);
// xin will be Int64[] {0,25,0,38,0,19,0 ...}
// Infer. Both Single(not tested) and Multi speaker are supported.
var res = model.Run(xin,sid:2);
// Save Wav File at sr=22050 configured by Nene.json
SaveWavFile(res, 22050, "out.wav");
(现在仅仅处于试验阶段。已经在Demo中实现。)
读取方法:
FileStream file = File.Open(@"Nene.zip", FileMode.Open);
ZipArchive zip = new ZipArchive(file);
JsonModelConfig cfg = new();
var configjson = zip.GetEntry("config.json");
if(configjson != null)
{
using (var jstream = configjson.Open())
{
cfg = System.Text.Json.JsonSerializer.Deserialize<JsonModelConfig>(jstream);
}
}
// 直接输入symbols中包括的数据(还没做cleaner)
string text = "ohayougozaimasu!harukun";
var indecies = Text2SymbolIndex(text, cfg.Symbol); //cfg内容未作检查
// Here we can load the Zip Archive directly.
var model = new OnnxVitsLib.VitsModel(file, isMultiSpeaker: true);
var xin = add0(indecies);
VitsModelRunOptions runOptions = new()
{
length_scale = 1.2F
};
var res = model.Run(xin, 1,runOptions); //sid范围未作检查
SaveWavFile(res, cfg.Rate, "out1.wav");
压缩包内容如下(应该不用解释罢):
Nene.zip
├── config.json
├── dec.onnx
├── dp.onnx
├── emb.onnx
├── enc_p.onnx
└── flow.onnx
压缩包的直接读取目前只支持zip。json格式与其说兼容,不如说参照的事M佬的MoeSS.
- 易用性:
- UI
- 实时播放
- 前端:
- japanese_cleaners
- japanese_cleaners2
- cjke
- other cleaners
- 后端:
- 读取配置的json
- 读取配置的json(仅仅Demo中实现)
- onnx骨架
- 输出wav
- 多格式输出
- https://github.com/jaywalnut310/vits
- https://github.com/CjangCjengh/vits
- https://github.com/CjangCjengh/MoeGoe
- https://github.com/CjangCjengh/TTSModels
- https://github.com/NaruseMioShirakana/JapaneseCleaner
- https://github.com/Winter-of-Cirno/MoeGoeONNX