indri-0.1-124m-tts / README.md
cmeraki's picture
Updated README
6cb714c
|
raw
history blame
2.8 kB
---
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}},
}
```