Safetensors
Chinese
qwen2
File size: 5,249 Bytes
9f44d6b
 
 
 
 
 
 
 
 
 
8ff404a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
dcfa9f2
 
8ff404a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e7332ea
8ff404a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9f44d6b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
---
license: apache-2.0
datasets:
- amphion/Emilia-Dataset
- simon3000/genshin-voice
language:
- zh
base_model:
- Qwen/Qwen2-0.5B
---
# <center>ViiTor-Voice</center>
### <center>An LLM based TTS Engine</center>

<p align="center">
  <img src="post.webp" alt="Viitor-Voice Cover">
</p>

## Features

- **Lightweight Design**  

  The model is simple and efficient, compatible with most LLM inference engines. With only 0.5B parameters, it achieves extreme optimization of computational resources while maintaining high performance. This design allows the model to be deployed not only on servers but also on mobile devices and edge computing environments, meeting diverse deployment needs.

- **Real-time Streaming Output, Low Latency Experience**  

  The model supports real-time speech generation, suitable for applications that demand low latency. On the Tesla T4 platform, it achieves an industry-leading first-frame latency of 200ms, providing users with nearly imperceptible instant feedback, ideal for interactive applications requiring quick response.

- **Rich Voice Library**  

  Offers more than 300 different voice options, allowing you to choose the most suitable speech style according to your needs and preferences. Whether it’s a formal business presentation or casual entertainment content, the model provides perfect voice matching.

- **Flexible Speech Rate Adjustment**  

  The model supports natural variations in speech rate, allowing users to easily adjust it based on content requirements and audience preferences. Whether speeding up for efficient information delivery or slowing down to enhance emotional depth, it maintains natural speech fluency.

- **Zero-shot Voice Cloning (Under Research)**  

  Decoder-only architecture naturally supports Zero-shot cloning, with future support for rapid voice cloning based on minimal voice samples.

---

## Output Samples

Below are examples of speech generated by this project:

### English Female Voice 1:

https://github.com/user-attachments/assets/395bcdeb-1899-43b2-aff9-358bdc5f1c29

### English Male Voice 1:

https://github.com/user-attachments/assets/d373f2fd-4b35-4b42-983f-3a5f0c25779d

### Chinese Female Voice 1:

https://github.com/user-attachments/assets/94d6da03-bc71-4f7c-8453-9312a1eb6d1e

### Chinese Male Voice 1:

https://github.com/user-attachments/assets/8a03785b-8100-48fe-8d64-fd98406aab1d


---

## Environment Setup

```commandline
git clone https://github.com/viitor-ai/viitor-voice.git
cd viitor-voice
conda create -n viitor_voice python=3.10
conda activate viitor_voice
pip install -r requirements.txt

### Due to the issue with vllm's tokenizer length calculation, the token limit cannot take effect.
python_package_path=`pip show pip | egrep Location | awk -F ' ' '{print $2}'`
cp viitor_voice/utils/patch.py $python_package_path/vllm/entrypoints/openai/logits_processors.py
```

---

## Inference
### Pretrained Models
- [English](https://huggingface.co/ZzWater/viitor-voice-en)
- [Chinese](https://huggingface.co/ZzWater/viitor-voice-chs)
### Offline Inference

```python
from viitor_voice.utils.offline_inference import OfflineInference
import torchaudio

## English
tts_engine = OfflineInference(model_path='ZzWater/viitor-voice-en',
                              config_path='viitor_voice/inference_configs/en.json')
text_list = [
    "Isn't it fascinating to think about the endless possibilities that lie within the pages of a book. every time you turn a page, you're diving into a new world ripe with potential for discovery, and wonder what stories will you uncover today."]
# list valid speakers

print(tts_engine.prompt_map.keys())
audios = tts_engine.batch_infer(text_list=text_list, speaker=['1'], speed=2)
torchaudio.save('test.wav', audios[0], 24000)

## Chinese
tte_engine_chs = OfflineInference(model_path='ZzWater/viitor-voice-chs',
                                  config_path='viitor_voice/inference_configs/chs.json')
text_list_chs = [
    "我觉得我还是可以抢救一下的。"]
audios = tte_engine_chs.batch_infer(text_list=text_list_chs, speaker=['female1'], speed=2)
torchaudio.save('test_chs.wav', audios[0], 24000)





```

### Demo Inference
- [ViiTor AI](https://www.viitor.io/text-to-speech)
### Streaming Inference (TODO)

---
## Training (TODO)
## Join Our Community
[![Join Discord](https://img.shields.io/discord/your-discord-id?logo=discord&style=for-the-badge)](https://discord.gg/MbxgFn7BN8)

Have questions about the project? Want to discuss new features, report bugs, or just chat with other contributors? Join our Discord community!
## References

- [SNAC](https://github.com/hubertsiuzdak/snac)
- [mini-omni](https://github.com/gpt-omni/mini-omni)
- [open-gpt-4-o](https://laion.ai/notes/open-gpt-4-o/)

## License

This project is licensed under [CC BY-NC 4.0](https://creativecommons.org/licenses/by-nc/4.0/).  
You are free to share and modify the code of this project for non-commercial purposes, under the following conditions:

1. **Attribution**: You must give appropriate credit, provide a link to the license, and indicate if changes were made.
2. **Non-Commercial**: You may not use the material for commercial purposes.

**Copyright Notice:**  
© 2024 Livedata. All Rights Reserved.