经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 大数据/云/AI » 人工智能基础 » 查看文章
ChatTTS,语气韵律媲美真人的开源TTS模型,文字转语音界的新魁首,对标微软Azure-tts
来源:cnblogs  作者:刘悦的技术博客  时间:2024/5/31 17:06:36  对本文有异议

前两天 2noise 团队开源了ChatTTS项目,并且释出了相关的音色模型权重,效果确实非常惊艳,让人一听难忘,即使摆在微软的商业级项目Azure-tts面前,也是毫不逊色的。

ChatTTS是专门为对话场景设计的文本转语音模型,例如大语言助手对话任务。它支持英文和中文两种语言。最大的模型使用了10万小时以上的中英文数据进行训练。目前在huggingface中的开源版本为4万小时训练且未SFT的版本。

本次分享一下如何在本地部署ChatTTS项目。

配置ChatTTS环境

首先确保本地已经安装好Anaconda软件包,运行命令创建虚拟环境:

  1. conda create -n ChatTTS python=3.11

之所以选择Python3.11的版本,是因为该版本的整体性能更好。

随后克隆官方的项目:

  1. git clone https://github.com/2noise/ChatTTS.git

进入项目

  1. cd ChatTTS

激活虚拟环境

  1. conda activate ChatTTS

安装项目依赖:

  1. pip install -r requirements.txt

最后安装gpu版本的torch:

  1. pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu121

注意这里默认的cuda版本是12.1,如果你的本地cuda是11.8,那么就安装对应11.8的torch:

  1. pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118

至此,环境就配置好了。

ChatTTS的基本使用

首先,是最基本的文字转语音功能:

  1. import ChatTTS
  2. from IPython.display import Audio
  3. chat = ChatTTS.Chat()
  4. chat.load_models()
  5. texts = ["你好啊",]
  6. wavs = chat.infer(texts, use_decoder=True)
  7. Audio(wavs[0], rate=24_000, autoplay=True)

这里 ChatTTS 是项目内的文件夹模块,初始化后直接调用infer方法即可进行音频推理。

需要注意的是,首次运行会默认在Huggingface上下载模型,需要学术上网环境。

ChatTTS的进阶用法

  1. ###################################
  2. # Sample a speaker from Gaussian.
  3. import torch
  4. std, mean = torch.load('ChatTTS/asset/spk_stat.pt').chunk(2)
  5. rand_spk = torch.randn(768) * std + mean
  6. params_infer_code = {
  7. 'spk_emb': rand_spk, # add sampled speaker
  8. 'temperature': .3, # using custom temperature
  9. 'top_P': 0.7, # top P decode
  10. 'top_K': 20, # top K decode
  11. }
  12. ###################################
  13. # For sentence level manual control.
  14. # use oral_(0-9), laugh_(0-2), break_(0-7)
  15. # to generate special token in text to synthesize.
  16. params_refine_text = {
  17. 'prompt': '[oral_2][laugh_0][break_6]'
  18. }
  19. wav = chat.infer("<PUT YOUR TEXT HERE>", params_refine_text=params_refine_text, params_infer_code=params_infer_code)
  20. ###################################
  21. # For word level manual control.
  22. # use_decoder=False to infer faster with a bit worse quality
  23. text = 'What is [uv_break]your favorite english food?[laugh][lbreak]'
  24. wav = chat.infer(text, skip_refine_text=True, params_infer_code=params_infer_code, use_decoder=False)

这里通过 std, mean = torch.load('ChatTTS/asset/spk_stat.pt').chunk(2) 方法来固定音色。

随后通过 params_refine_text 来人为的增加笑声和断句。

ChatTTS的中文样例

最后是一个ChatTTS的中文推理例子:

  1. inputs_cn = """
  2. chat T T S 是一款强大的对话式文本转语音模型。它有中英混读和多说话人的能力。
  3. chat T T S 不仅能够生成自然流畅的语音,还能控制[laugh]笑声啊[laugh],
  4. 停顿啊[uv_break]语气词啊等副语言现象[uv_break]。这个韵律超越了许多开源模型[uv_break]。
  5. 请注意,chat T T S 的使用应遵守法律和伦理准则,避免滥用的安全风险。[uv_break]'
  6. """.replace('\n', '')
  7. params_refine_text = {
  8. 'prompt': '[oral_2][laugh_0][break_4]'
  9. }
  10. audio_array_cn = chat.infer(inputs_cn, params_refine_text=params_refine_text)
  11. audio_array_en = chat.infer(inputs_en, params_refine_text=params_refine_text)

文本内容可以通过[laugh]和[uv_break]标识来进行笑声和语气停顿的定制化操作

结语

诚然,没有完美的产品,ChatTTS的模型稳定性似乎还有待提高, 偶尔会出现其他音色或音质很差的现象,这是自回归模型通常都会出现的问题,说话人的音色也有可能会在一定范围内变化, 可能会采样到音质非常差的结果, 这通常难以避免. 可以多采样几次来找到合适的结果,俗称抽卡,最后奉上一键整合包,与众乡亲同飨:

  1. ChatTTS新版整合包:https://pan.quark.cn/s/e07f47edf82a

原文链接:https://www.cnblogs.com/v3ucn/p/18224909

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号