轻量级开源TTS模型 支持自定义语音特征
Parler-TTS是一个轻量级开源文本转语音模型,通过文本提示控制语音特征如性别、语速和音调。项目提供完整训练和推理代码及预训练模型,便于用户定制TTS模型。最新版本引入SDPA和Flash Attention 2,显著提升生成速度。该模型支持随机声音生成和特定说话人复制,适用于多种TTS应用场景。
Parler-TTS是一个轻量级的文本转语音(TTS)模型,可以生成高质量、自然流畅的语音,并能模仿特定说话者的风格(性别、音调、说话方式等)。这是对Stability AI的Dan Lyth和爱丁堡大学的Simon King所发表的论文《Natural language guidance of high-fidelity text-to-speech with synthetic annotations》中研究成果的复现。
与其他TTS模型不同,Parler-TTS是一个完全开源的发布版本。所有数据集、预处理、训练代码和权重都以宽松的许可证公开发布,使社区能够在我们的工作基础上开发他们自己的强大TTS模型。
本仓库包含Parler-TTS的推理和训练代码。它旨在与Data-Speech仓库配合使用,用于数据集标注。
[!重要] 2024年8月8日: 我们很自豪地发布两个新的Parler-TTS检查点:
- Parler-TTS Mini,一个880M参数的模型。
- Parler-TTS Large,一个2.3B参数的模型。
这些检查点已在45,000小时的有声读物数据上进行了训练。
此外,代码经过优化,生成速度大大提高:我们增加了SDPA和Flash Attention 2的兼容性,以及编译模型的功能。
Parler-TTS的依赖项很轻量,可以通过一行命令安装:
pip install git+https://github.com/huggingface/parler-tts.git
Apple Silicon用户需要运行以下命令以使用PyTorch(2.4)的每夜版构建,以支持bfloat16:
pip3 install --pre torch torchaudio --index-url https://download.pytorch.org/whl/nightly/cpu
[!提示] 你可以直接在这里的交互式演示中试用!
使用Parler-TTS就像说"你好"一样简单。只需一次性安装库:
pip install git+https://github.com/huggingface/parler-tts.git
Parler-TTS经过训练,可以生成具有可控特征的语音,这些特征可以通过简单的文本提示来控制,例如:
import torch from parler_tts import ParlerTTSForConditionalGeneration from transformers import AutoTokenizer import soundfile as sf device = "cuda:0" if torch.cuda.is_available() else "cpu" model = ParlerTTSForConditionalGeneration.from_pretrained("parler-tts/parler-tts-mini-v1").to(device) tokenizer = AutoTokenizer.from_pretrained("parler-tts/parler-tts-mini-v1") prompt = "嘿,你今天过得怎么样?" description = "一位女性说话者以略带表情和生动的方式发言,语速和音调适中。录音质量非常高,说话者的声音清晰且非常贴近。" input_ids = tokenizer(description, return_tensors="pt").input_ids.to(device) prompt_input_ids = tokenizer(prompt, return_tensors="pt").input_ids.to(device) generation = model.generate(input_ids=input_ids, prompt_input_ids=prompt_input_ids) audio_arr = generation.cpu().numpy().squeeze() sf.write("parler_tts_out.wav", audio_arr, model.config.sampling_rate)
为确保生成过程中说话者的一致性,此检查点还在34位说话者上进行了训练,每位说话者都有特定的名字(如Jon、Lea、Gary、Jenna、Mike、Laura)。
要利用这一特性,只需调整你的文本描述以指定使用哪位说话者:"Jon的声音单调但语速略快,录音非常贴近,几乎没有背景噪音。"
import torch from parler_tts import ParlerTTSForConditionalGeneration from transformers import AutoTokenizer import soundfile as sf device = "cuda:0" if torch.cuda.is_available() else "cpu" model = ParlerTTSForConditionalGeneration.from_pretrained("parler-tts/parler-tts-mini-v1").to(device) tokenizer = AutoTokenizer.from_pretrained("parler-tts/parler-tts-mini-v1") prompt = "嘿,你今天过得怎么样?" description = "Jon的声音单调但语速略快,录音非常贴近,几乎没有背景噪音。" input_ids = tokenizer(description, return_tensors="pt").input_ids.to(device) prompt_input_ids = tokenizer(prompt, return_tensors="pt").input_ids.to(device) generation = model.generate(input_ids=input_ids, prompt_input_ids=prompt_input_ids) audio_arr = generation.cpu().numpy().squeeze() sf.write("parler_tts_out.wav", audio_arr, model.config.sampling_rate)
提示:
我们设置了一个推理指南来加快生成速度。考虑使用SDPA、torch.compile和流式处理!
训练文件夹包含了训练或微调你自己的Parler-TTS模型所需的所有信息。它包括:
[!重要] 简而言之: 在完成安装步骤后,你可以使用以下命令行重现Parler-TTS Mini v1训练配方:
accelerate launch ./training/run_parler_tts_training.py ./helpers/training_configs/starting_point_v1.json
[!重要] 你也可以按照这个微调指南在单一说话人数据集上进行实验。
这个库建立在许多开源巨人的基础之上,我们想向他们提供这些工具表示最衷心的感谢!
特别感谢:
如果你发现这个仓库有用,请考虑引用这项工作以及原始的Stability AI论文:
@misc{lacombe-etal-2024-parler-tts,
author = {Yoach Lacombe and Vaibhav Srivastav and Sanchit Gandhi},
title = {Parler-TTS},
year = {2024},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/huggingface/parler-tts}}
}
@misc{lyth2024natural,
title={Natural language guidance of high-fidelity text-to-speech with synthetic annotations},
author={Dan Lyth and Simon King},
year={2024},
eprint={2402.01912},
archivePrefix={arXiv},
primaryClass={cs.SD}
}
我们欢迎贡献,因为这个项目为改进和探索提供了许多可能性。
具体来说,我们正在寻找提高质量和速度的方法:
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
字节跳动发布的AI编程神器IDE
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI助力,做PPT更简单!
咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。
选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。
专业的AI公文写作平台,公文写作神器
AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。
OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。
openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。
高分辨率纹理 3D 资产生成
Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。
一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。
3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号