--- license: cc-by-4.0 datasets: - speechcolab/gigaspeech - parler-tts/mls_eng_10k - reach-vb/jenny_tts_dataset language: - en - hi base_model: - openai-community/gpt2 pipeline_tag: text-to-speech --- # Model Card for indri-0.1-125m-tts Indri is a series of audio models that can do TTS, ASR, and audio continuation. This is the smallest model (125M) in our series and supports TTS tasks in 2 languages: 1. English 2. Hindi We have open-sourced our training scripts, inference, and other details. - **Repository:** [GitHub](https://github.com/cmeraki/indri) - **Demo:** [Website](https://www.indrivoice.ai/) - **Implementation details**: [Release Blog](#TODO) ## Model Details ### Model Description `indri-0.1-125m-tts` is a novel, ultra-small, and lightweight TTS model based on the transformer architecture. It models audio as tokens and can generate high-quality audio with consistent style cloning of the speaker. ### Key features 1. Based on GPT-2 architecture. The methodology can be extended to any transformer-based architecture. 2. Supports voice cloning with small prompts (<5s). 3. Code mixing text input in 2 languages - English and Hindi. 4. Ultra-fast. Can generate 5 seconds of audio per second on Amphere generation NVIDIA GPUs, and up to 10 seconds of audio per second on Ada generation NVIDIA GPUs. ### Details 1. Model Type: GPT-2 based language model 2. Size: 125M parameters 3. Language Support: English, Hindi 4. License: CC BY 4.0 ## Technical details Here's a brief of how the model works: 1. Converts input text into tokens 2. Runs autoregressive decoding on GPT-2 based transformer model and generates audio tokens 3. Decodes audio tokens (from [Kyutai/mimi](https://huggingface.co/kyutai/mimi)) to audio Please read our blog [here](#TODO) for more technical details on how it was built. ## How to Get Started with the Model Use the code below to get started with the model. Pipelines are the best way to get started with the model. ```python import torch import torchaudio from transformers import pipeline task = 'indri-tts' model_id = '11mlabs/indri-0.1-125m-tts' pipe = pipeline( task, model=model_id, device=torch.device('cuda:0'), # Update this based on your hardware, trust_remote_code=True ) output = pipe(['Hi, my name is Indri and I like to talk.']) torchaudio.save('output.wav', output[0]['audio'][0], sample_rate=24000) ``` ## Credits 1. [Kyutai/mimi](https://huggingface.co/kyutai/mimi) 2. [nanoGPT](https://github.com/karpathy/nanoGPT) ## Citation To cite our work ``` @misc{indri-0.1-125m-tts, author = {11mlabs}, title = {indri-0.1-125m-tts}, year = 2024, publisher = {Hugging Face}, journal = {GitHub Repository}, howpublished = {\url{https://github.com/cmeraki/indri}}, } ```