index-tts-lora
本项目基于哔哩哔哩的index-tts,为单说话人和多说话人场景提供LoRA微调解决方案。旨在提升高质量说话人音频合成中的韵律和自然度。
训练与推理
#### 1. 音频标记和说话人条件提取
# Extract tokens and speaker conditions
python tools/extract_codec.py --audio_list ${audio_list} --extract_conditionaudio_list format: audio_path + transcript, separated by \t
/path/to/audio.wav 小朋友们,大家好,我是凯叔,今天我们讲一个龟兔赛跑的故事。
提取完成后,处理过的文件和 speaker_info.json 将生成在 finetune_data/processed_data/ 目录下。例如:[
{
"speaker": "kaishu_30min",
"avg_duration": 6.6729,
"sample_num": 270,
"total_duration_in_seconds": 1801.696,
"total_duration_in_minutes": 30.028,
"total_duration_in_hours": 0.500,
"train_jsonl": "/path/to/kaishu_30min/metadata_train.jsonl",
"valid_jsonl": "/path/to/kaishu_30min/metadata_valid.jsonl",
"medoid_condition": "/path/to/kaishu_30min/medoid_condition.npy"
}
]#### 2. 训练
python train.py#### 3. 推理
python indextts/infer.py微调结果
本实验使用来自凯叔讲故事的中文音频数据,总时长约为30分钟,共270条音频片段。 数据集被划分为244条训练样本和26条验证样本。 注意:转录文本由ASR和标点模型自动生成,未经过人工校正,因此可能存在一些错误。
训练样例,例如 他上了马车,来到了皇宫之中。:kaishu_train_01.wav
#### 1. 语音合成示例
| 文本 | 音频 | | ------------------------------------------------------------ | ------------------------------------------------------------ | | 老宅的钟表停在午夜三点,灰尘中浮现一串陌生脚印。侦探蹲下身,发现地板缝隙里藏着一枚带血的戒指。 | kaishu_cn_1.wav | | 月光下,南瓜突然长出笑脸,藤蔓扭动着推开花园栅栏。小女孩踮起脚,听见蘑菇在哼唱古老的摇篮曲。 | kaishu_cn_2.wav | | 那么Java里面中级还要学,M以及到外部前端的应用系统开发,要学到Java Script的数据库,要学做动态的网站。 | kaishu_cn_en_mix_1.wav | | 这份 financial report 详细分析了公司在过去一个季度的 revenue performance 和 expenditure trends。 | kaishu_cn_en_mix_2.wav | | 上山下山上一山,下一山,跑了三里三米三,登了一座大高山,山高海拔三百三。上了山,大声喊:我比山高三尺三。 | kaishu_raokouling.wav | | A thin man lies against the side of the street with his shirt and a shoe off and bags nearby. | kaishu_en_1.wav | | As research continued, the protective effect of fluoride against dental decay was demonstrated. | kaishu_en_2.wav |
#### 2. 模型评估
致谢
--- Tranlated By Open Ai Tx | Last indexed: 2025-12-28 ---