{"id":13901174,"url":"https://github.com/kuangdd/ttskit","last_synced_at":"2025-07-17T21:32:31.833Z","repository":{"id":38338773,"uuid":"413072505","full_name":"kuangdd/ttskit","owner":"kuangdd","description":"text to speech toolkit. 好用的中文语音合成工具箱，包含语音编码器、语音合成器、声码器和可视化模块。","archived":false,"fork":false,"pushed_at":"2022-02-20T15:51:02.000Z","size":58838,"stargazers_count":1037,"open_issues_count":41,"forks_count":204,"subscribers_count":14,"default_branch":"main","last_synced_at":"2024-07-11T03:43:32.358Z","etag":null,"topics":["audio","chinese","tts","vc"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kuangdd.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2021-10-03T12:33:46.000Z","updated_at":"2024-07-10T15:23:11.000Z","dependencies_parsed_at":"2022-07-14T04:50:30.878Z","dependency_job_id":null,"html_url":"https://github.com/kuangdd/ttskit","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuangdd%2Fttskit","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuangdd%2Fttskit/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuangdd%2Fttskit/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuangdd%2Fttskit/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kuangdd","download_url":"https://codeload.github.com/kuangdd/ttskit/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":214254540,"owners_count":15706263,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["audio","chinese","tts","vc"],"created_at":"2024-08-06T21:00:58.303Z","updated_at":"2024-08-06T21:01:41.074Z","avatar_url":"https://github.com/kuangdd.png","language":"Python","funding_links":[],"categories":["Python"],"sub_categories":[],"readme":"\n![ttskit](ttskit.png \"ttskit\")\n\n## ttskit\nText To Speech Toolkit: 语音合成工具箱。\n\n### 安装\n\n```\npip install -U ttskit\n```\n\n- 注意\n    * 可能需另外安装的依赖包：torch，版本要求torch\u003e=1.6.0,\u003c=1.7.1，根据自己的实际环境安装合适cuda或cpu版本的torch。\n    * ttskit的默认音频采样率为22.5k。\n    * 自行设置环境变量CUDA_VISIBLE_DEVICES以调用GPU，如果不设置，则默认调用0号GPU，没有GPU则使用CPU。\n    * 默认用mspk模式的多发音人的语音合成模型，griffinlim声码器。\n\n### 语音合成Demo网页\n\nhttp://119.91.208.249:9000/ttskit\n\n### 资源\n使用ttskit的过程中会自动下载模型和语音资源。\n\n如果下载太慢或无法下载，也可自行从百度网盘下载，把下载的资源合并到ttskit目录下（更新resource目录）。\n\n链接：https://pan.baidu.com/s/13RPGNEKrCX3fgiGl7P5bpw\n\n提取码：b7hw\n\n### 快速使用\n```\nimport ttskit\n\nttskit.tts('这是个示例', audio='14')\n\n# 参数介绍\n'''语音合成函数式SDK接口，函数参数全部为字符串格式。\ntext为待合成的文本。\nspeaker为发音人名称，可选名称为_reference_audio_dict；默认的发音人名称列表见resource/reference_audio/__init__.py。\naudio为发音人参考音频，如果是数字，则调用内置的语音作为发音人参考音频；如果是语音路径，则调用audio路径的语音作为发音人参考音频。\n注意：如果用speaker来选择发音人，请把audio设置为下划线【_】。\noutput为输出，如果以.wav结尾，则为保存语音文件的路径；如果以play开头，则合成语音后自动播放语音。\n'''\n```\n\n    ### 版本\n    v0.3.8\n    \n### sdk_api\n语音合成SDK接口。\n本地函数式地调用语音合成。\n\n+ 简单使用\n```python\nfrom ttskit import sdk_api\n\nwav = sdk_api.tts_sdk('文本', audio='24')\n```\n\n### cli_api\n语音合成命令行接口。\n用命令行调用语音合成。\n\n+ 简单使用\n```python\nfrom ttskit import cli_api\n\nargs = cli_api.parse_args()\ncli_api.tts_cli(args)\n# 命令行交互模式使用语音合成。\n```\n\n+ 命令行\n```\ntkcli\n\nusage: tkcli [-h] [-i INTERACTION] [-t TEXT] [-s SPEAKER] [-a AUDIO]\n             [-o OUTPUT] [-m MELLOTRON_PATH] [-w WAVEGLOW_PATH] [-g GE2E_PATH]\n             [--mellotron_hparams_path MELLOTRON_HPARAMS_PATH]\n             [--waveglow_kwargs_json WAVEGLOW_KWARGS_JSON]\n\n语音合成命令行。\n\noptional arguments:\n  -h, --help            show this help message and exit\n  -i INTERACTION, --interaction INTERACTION\n                        是否交互，如果1则交互，如果0则不交互。交互模式下：如果不输入文本或发音人，则为随机。如果输入文本为exit\n                        ，则退出。\n  -t TEXT, --text TEXT  Input text content\n  -s SPEAKER, --speaker SPEAKER\n                        Input speaker name\n  -a AUDIO, --audio AUDIO\n                        Input audio path or audio index\n  -o OUTPUT, --output OUTPUT\n                        Output audio path. 如果play开头，则播放合成语音；如果.wav结尾，则保存语音。\n  -m MELLOTRON_PATH, --mellotron_path MELLOTRON_PATH\n                        Mellotron model file path\n  -w WAVEGLOW_PATH, --waveglow_path WAVEGLOW_PATH\n                        WaveGlow model file path\n  -g GE2E_PATH, --ge2e_path GE2E_PATH\n                        Ge2e model file path\n  --mellotron_hparams_path MELLOTRON_HPARAMS_PATH\n                        Mellotron hparams json file path\n  --waveglow_kwargs_json WAVEGLOW_KWARGS_JSON\n                        Waveglow kwargs json\n```\n\n\n### web_api\n语音合成WEB接口。\n构建简单的语音合成服务。\n\n+ 简单使用\n```python\nfrom ttskit import web_api\n\nweb_api.app.run(host='0.0.0.0', port=2718, debug=False)\n# 用POST或GET方法请求：http://localhost:2718/tts，传入参数text、audio、speaker。\n# 例如GET方法请求：http://localhost:2718/tts?text=这是个例子\u0026audio=2\n```\n\n+ 使用说明\n\n### http_server\n语音合成简易界面。\n构建简单的语音合成网页服务。\n\n+ 简单使用\n```python\nfrom ttskit import http_server\n\nhttp_server.start_sever()\n# 打开网页：http://localhost:9000/ttskit\n```\n\n+ 命令行\n```\ntkhttp\n\nusage: tkhttp [-h] [--device DEVICE] [--host HOST] [--port PORT]\n\noptional arguments:\n  -h, --help       show this help message and exit\n  --device DEVICE  设置预测时使用的显卡,使用CPU设置成-1即可\n  --host HOST      IP地址\n  --port PORT      端口号\n```\n\n+ 网页界面\n![index](ttskit/templates/index.png \"index\")\n\n+ 注意事项\n    1. 模式mode\n        - 可选：mspk、rtvc\n        - 默认：mspk\n    2. 声码器vocoder\n        - 可选：melgan、griffinlim、waveglow\n        - 默认：melgan\n        - melgan控制参数\n            * vocoder: melgan\n        - griffinlim控制参数\n            * vocoder: griffinlim\n            * griffinlim_iters: 30\n        - waveglow控制参数\n            * vocoder: waveglow\n            * sigma: 1.0\n            * denoiser_strength: 1.2\n    3. 参考音频audio\n        - 可选：1-24的整数（内置的24个参考音频）、下划线_（）\n        - POST请求接口：可传入wav音频的base64编码的字符串。\n    4. 发音人speaker\n        - 可选：Aibao、Aicheng、Aida、Aijia、Aijing、Aimei、Aina、Aiqi、Aitong、Aiwei、Aixia、Aiya、Aiyu、Aiyue、Siyue、Xiaobei、Xiaogang、Xiaomei、Xiaomeng、Xiaowei、Xiaoxue、Xiaoyun、Yina、biaobei\n\n### resource\n模型数据等资源。\n\naudio\nmodel\nreference_audio\n\n+ 内置发音人映射表\n\n```python\n_speaker_dict = {\n    1: 'Aibao', 2: 'Aicheng', 3: 'Aida', 4: 'Aijia', 5: 'Aijing',\n    6: 'Aimei', 7: 'Aina', 8: 'Aiqi', 9: 'Aitong', 10: 'Aiwei',\n    11: 'Aixia', 12: 'Aiya', 13: 'Aiyu', 14: 'Aiyue', 15: 'Siyue',\n    16: 'Xiaobei', 17: 'Xiaogang', 18: 'Xiaomei', 19: 'Xiaomeng', 20: 'Xiaowei',\n    21: 'Xiaoxue', 22: 'Xiaoyun', 23: 'Yina', 24: 'biaobei'\n}\n```\n\n### encoder\n#### 声音编码器（encoder）\n- 把语音音频编码为指定维度的向量。\n- 向量的相似度反映音频音色的相似度。如果两个音频的编码向量相似度越高，则这两个音频的音色越接近。\n- 编码向量主要用于控制发音的音色。\n\n#### GE2E声音编码器\n- 谷歌在上发布了GE2E算法的论文，详细介绍了其声纹识别技术的核心实现方法。\n- 这是一种基于批（batch）的训练方法，这种基于批的训练，则是将同一批中每个说话者与其最相似的说话者的声纹特征变得不同。\n- 论文通过理论和实验论证了，这种始终针对最困难案例进行优化的训练方式，能够极大地提升训练速度和效果。\n\n### mellotron\n#### 语音合成器（synthesizer）\n- 把文本转为语音频谱数据。\n- 语音合成器接收声音编码向量和文本数据，然后结合这些信息把文本转为语音频谱。\n- 语音合成器的任务是把文本转为语音频谱，本质上是序列到序列的任务。\n- 可以把文本看做一个一个字组成的序列，把语音频谱看做是由一个一个语音特征组成的序列，语音合成器就是把文字序列转为语音特征序列的桥梁。\n- 语音合成器的关键就是怎样建立模型让文字准确的转为正确的读音，而且放在正确的位置，同时读音前后应当衔接自然，而且整个语音听起来也应当自然。\n- 要实现这样的目标，应当做很有针对性的模型。\n\n#### Mellotron语音合成器\n- Mellotron是英伟达团队提出的语音合成模型，主要目标是做韵律风格转换和音乐生成。\n- Mellotron可以更加精细化的调整韵律和音调，将基频信息引入模型刻画声调信息，基频是区别音高的主要元素。\n- Mellotron模型的训练完全端到端化，不需要在数据集中含有音乐数据也可以生成音乐。\n- Mellotron不需要对音调和文本进行人为的对齐就可以学到两者之间的对齐关系。\n- Mellotron可以使用外部输入的注意力映射表，从而实现韵律迁移。\n\n### waveglow\n#### 声码器（vocoder）\n- 把语音频谱数据转为语音信号。\n- 语音信号和语音频谱数据并不是简单可以相互转换的数据，语音转为频谱是有信息丢失的，但是频谱记录了语音最主要的信息，可以通过其他技术手段把语音频谱尽可能逼真地逆变为语音信号，声码器就是这样的技术。\n- 声码器是把声音特征转为语音信号的技术。\n- 在语音合成任务中，声码器是负责把语音频谱转为语音信号。\n- 通常语音频谱记录的语音信息并不是全面的，例如mel频谱只是记录了部分频段的幅度信息，缺失了相位信息，而且许多频率的信息也丢失了。\n- 而声码器模型就是要从这样的频谱中尽可能准确全面地还原出语音信号。\n- 现在通常的方案是用深度学习的方法来解决，针对语音特征和语音信号的关系进行建模。\n\n#### Waveglow声码器\n- WaveGlow是英伟达团队提出的一种依靠流的从梅尔频谱图合成高质量语音的模型。\n- Waveglow贡献是基于流的网络，结合了Glow和WaveNet的想法，因此网络称为WaveGlow 。\n- WaveGlow是一个生成模型，通过从分布采样中生成音频。\n- WaveGlow易于实施，仅使用单个网络进行训练，仅使用似然损失函数进行训练。\n- WaveGlow是兼顾生成速度快、生成质量高、稳定性强的模型。\n\n#### MelGAN声码器\n- MelGAN采用非自回归前馈卷积架构，在不引入额外蒸馏和感知损失的前提下，依然能够产生高质量的语音。\n- MelGAN是一种利用生成对抗网络（Generative Adversarial Networks，GANs）合成时域波形的方法。\n- MelGAN由于模型计算复杂度低，并行度高，因而合成速度极快。\n- MelGAN是基于GAN的生成模型，因而主要由生成器和判别器组成。\n- 生成器输入语音的压缩表示，如梅尔频谱，经过一层卷积后送入上采样层，上采样将梅尔频谱的序列长度匹配波形的频率。\n- 对于判别器，主体是由卷积层和下采样层组成，并且采用多尺度架构，也就是不但对原始音频做判别，还将降频处理之后的音频馈送到判别器中进行判断。\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuangdd%2Fttskit","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkuangdd%2Fttskit","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuangdd%2Fttskit/lists"}