| --- |
| license: mit |
| language: |
| - ar |
| - da |
| - de |
| - el |
| - en |
| - es |
| - fi |
| - fr |
| - he |
| - hi |
| - it |
| - ja |
| - ko |
| - ms |
| - nl |
| - no |
| - pl |
| - pt |
| - ru |
| - sv |
| - sw |
| - tr |
| - zh |
| pipeline_tag: text-to-speech |
| tags: |
| - text-to-speech |
| - speech |
| - speech-generation |
| - voice-cloning |
| - multilingual-tts |
| library_name: chatterbox |
| --- |
| |
| <img width="800" alt="cb-big2" src="https://github.com/user-attachments/assets/bd8c5f03-e91d-4ee5-b680-57355da204d1" /> |
|
|
| <h1 style="font-size: 32px">Chatterbox TTS</h1> |
|
|
| <div style="display: flex; align-items: center; gap: 12px"> |
| <a href="https://resemble-ai.github.io/chatterbox_demopage/"> |
| <img src="https://img.shields.io/badge/listen-demo_samples-blue" alt="Listen to Demo Samples" /> |
| </a> |
| <a href="https://huggingface.co/spaces/ResembleAI/Chatterbox"> |
| <img src="https://huggingface.co/datasets/huggingface/badges/resolve/main/open-in-hf-spaces-sm.svg" alt="Open in HF Spaces" /> |
| </a> |
| <a href="https://podonos.com/resembleai/chatterbox"> |
| <img src="https://static-public.podonos.com/badges/insight-on-pdns-sm-dark.svg" alt="Insight on Podos" /> |
| </a> |
| </div> |
| |
| <div style="display: flex; align-items: center; gap: 8px;"> |
| <span style="font-style: italic;white-space: pre-wrap">Made with ❤️ by</span> |
| <img width="100" alt="resemble-logo-horizontal" src="https://github.com/user-attachments/assets/35cf756b-3506-4943-9c72-c05ddfa4e525" /> |
| </div> |
|
|
| **09/04 🔥 Introducing Chatterbox Multilingual in 23 Languages!** |
|
|
| We're excited to introduce **Chatterbox** and **Chatterbox Multilingual**, [Resemble AI's](https://resemble.ai) production-grade open source TTS models. Chatterbox Multilingual supports **Arabic, Danish, German, Greek, English, Spanish, Finnish, French, Hebrew, Hindi, Italian, Japanese, Korean, Malay, Dutch, Norwegian, Polish, Portuguese, Russian, Swedish, Swahili, Turkish, Chinese** out of the box. Licensed under MIT, Chatterbox has been benchmarked against leading closed-source systems like ElevenLabs, and is consistently preferred in side-by-side evaluations. |
|
|
| Whether you're working on memes, videos, games, or AI agents, Chatterbox brings your content to life. It's also the first open source TTS model to support **emotion exaggeration control**, a powerful feature that makes your voices stand out. Try it now on our [Hugging Face Gradio app.](https://huggingface.co/spaces/ResembleAI/Chatterbox) |
|
|
| If you like the model but need to scale or tune it for higher accuracy, check out our competitively priced TTS service (<a href="https://resemble.ai">link</a>). It delivers reliable performance with ultra-low latency of sub 200ms—ideal for production use in agents, applications, or interactive media. |
|
|
| # Key Details |
| - Multilingual, zero-shot TTS supporting 23 languages |
| - SoTA zeroshot English TTS |
| - 0.5B Llama backbone |
| - Unique exaggeration/intensity control |
| - Ultra-stable with alignment-informed inference |
| - Trained on 0.5M hours of cleaned data |
| - Watermarked outputs |
| - Easy voice conversion script |
| - [Outperforms ElevenLabs](https://podonos.com/resembleai/chatterbox) |
|
|
| # Tips |
| - **General Use (TTS and Voice Agents):** |
| - The default settings (`exaggeration=0.5`, `cfg=0.5`) work well for most prompts. |
| - If the reference speaker has a fast speaking style, lowering `cfg` to around `0.3` can improve pacing. |
|
|
| - **Expressive or Dramatic Speech:** |
| - Try lower `cfg` values (e.g. `~0.3`) and increase `exaggeration` to around `0.7` or higher. |
| - Higher `exaggeration` tends to speed up speech; reducing `cfg` helps compensate with slower, more deliberate pacing. |
|
|
| |
| ***Note:*** Ensure that the reference clip matches the specified language tag. Otherwise, language transfer outputs may inherit the accent of the reference clip’s language. |
| ***To mitigate this, set the CFG weight to 0.*** |
|
|
|
|
| # Installation |
| ``` |
| pip install chatterbox-tts |
| ``` |
|
|
|
|
| # Usage |
| ```python |
| import torchaudio as ta |
| from chatterbox.tts import ChatterboxTTS |
| |
| model = ChatterboxTTS.from_pretrained(device="cuda") |
| |
| text = "Ezreal and Jinx teamed up with Ahri, Yasuo, and Teemo to take down the enemy's Nexus in an epic late-game pentakill." |
| wav = model.generate(text) |
| ta.save("test-1.wav", wav, model.sr) |
| |
| # If you want to synthesize with a different voice, specify the audio prompt |
| AUDIO_PROMPT_PATH="YOUR_FILE.wav" |
| wav = model.generate(text, audio_prompt_path=AUDIO_PROMPT_PATH) |
| ta.save("test-2.wav", wav, model.sr) |
| ``` |
|
|
| # Multilingual Quickstart |
| ```python |
| import torchaudio as ta |
| from chatterbox.mtl_tts import ChatterboxMultilingualTTS |
| |
| multilingual_model = ChatterboxMultilingualTTS.from_pretrained(device="cuda") |
| |
| french_text = "Bonjour, comment ça va? Ceci est le modèle de synthèse vocale multilingue Chatterbox, il prend en charge 23 langues." |
| wav_french = multilingual_model.generate(french_text, language_id="fr") |
| ta.save("test-french.wav", wav_french, model.sr) |
| |
| chinese_text = "你好,今天天气真不错,希望你有一个愉快的周末。" |
| wav_chinese = multilingual_model.generate(chinese_text, language_id="zh") |
| ta.save("test-chinese.wav", wav_chinese, model.sr) |
| ``` |
| See `example_tts.py` for more examples. |
|
|
|
|
| # Acknowledgements |
| - [Cosyvoice](https://github.com/FunAudioLLM/CosyVoice) |
| - [HiFT-GAN](https://github.com/yl4579/HiFTNet) |
| - [Llama 3](https://github.com/meta-llama/llama3) |
|
|
| # Built-in PerTh Watermarking for Responsible AI |
|
|
| Every audio file generated by Chatterbox includes [Resemble AI's Perth (Perceptual Threshold) Watermarker](https://github.com/resemble-ai/perth) - imperceptible neural watermarks that survive MP3 compression, audio editing, and common manipulations while maintaining nearly 100% detection accuracy. |
|
|
| # Disclaimer |
| Don't use this model to do bad things. Prompts are sourced from freely available data on the internet. |