Create about_català.md
#3
by
martillopartbsc
- opened
- about_català.md +282 -0
about_català.md
ADDED
@@ -0,0 +1,282 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
## 📄 Sobre
|
2 |
+
TTS natural i eficient en català: utilitzant Matcha-TTS amb la llengua catalana.
|
3 |
+
|
4 |
+
Aquí trobaràs tota la informació sobre els nostres models Matxa 🍵 i alVoCat 🥑 , els quals han estat entrenats amb l'ús de l'aprenentatge profund. Si desitges informació específica sobre com entrenar aquests models, pots trobar-la [aquí](https://huggingface.co/BSC-LT/matcha-tts-cat-multispeaker) i [aquí](https://huggingface.co/BSC-LT/vocos-mel-22khz-cat) respectivament. El codi que hem utilitzat també es troba a Github [aquí](https://github.com/langtech-bsc/Matcha-TTS/tree/dev-cat).
|
5 |
+
|
6 |
+
## Taula de continguts
|
7 |
+
<details>
|
8 |
+
<summary>Fes clic per expandir</summary>
|
9 |
+
|
10 |
+
- [Descripció general del model](#descripció-general-del-model)
|
11 |
+
- [Usos previstos i limitacions](#usos-previstos-i-limitacions)
|
12 |
+
- [Mostres](#mostres)
|
13 |
+
- [Components principals](#components-principals)
|
14 |
+
- [El model en detall](#el-model-en-detall)
|
15 |
+
- [Adaptació al català](#adaptació-al-català)
|
16 |
+
- [Citació](#citació)
|
17 |
+
- [Informació adicional](#informació-adicional)
|
18 |
+
|
19 |
+
</details>
|
20 |
+
|
21 |
+
## Descripció general del model
|
22 |
+
|
23 |
+
La importància de les tecnologies de text-a-veu (TTS) de codi obert per a les llengües minoritàries mai és exagerada. Aquestes tecnologies democratitzen l'accés a les solucions de TTS, proporcionant un marc perquè les comunitats desenvolupin i adapten models segons les seves necessitats lingüístiques. Per això, utilitzant un conjunt de tecnologies, hem desenvolupat diferents solucions de TTS de codi obert i en català.
|
24 |
+
|
25 |
+
En primer lloc, vam crear un [model TTS per al català central](https://huggingface.co/BSC-LT/matcha-tts-cat-multispeaker) ajustant el model en anglès de Matcha-TTS. Matcha-TTS és un model d'avantguarda que utilitza aprenentatge profund, una forma d'IA, per entrenar models que reprodueixen patrons de parla humana. D'aquesta manera, permet generar veus sintètiques realistes a partir de text escrit. Després d'això, vam ajustar aquest model en català central per a tres altres dialectes catalans:
|
26 |
+
|
27 |
+
* Balear
|
28 |
+
* Nord-Occidental
|
29 |
+
* Valencià
|
30 |
+
|
31 |
+
|
32 |
+
## Usos previstos i limitacions
|
33 |
+
|
34 |
+
Aquest model està destinat a servir com a generador de característiques acústiques per a sistemes de text-a-veu multi-parlant per a la llengua catalana.
|
35 |
+
Ha estat ajustat mitjançant un fonemitzador català, per tant, si el model s'utilitza amb altres llengües, pot ser que no produeixi mostres intel·ligibles després de traár la seva sortida en forma d'ona de veu.
|
36 |
+
|
37 |
+
La qualitat de les mostres pot variar segons el locutor.
|
38 |
+
Això pot ser degut tan per la sensibilitat del model en aprendre freqüències específiques com per a la qualitat de les mostres per a cada locutor.
|
39 |
+
|
40 |
+
## Mostres
|
41 |
+
* Mostres femenines:
|
42 |
+
|
43 |
+
<table style="font-size:16px">
|
44 |
+
<col width="205">
|
45 |
+
<col width="205">
|
46 |
+
<td>Valencià</td>
|
47 |
+
<td>Nord-Occidental</td>
|
48 |
+
<td>Balear</td>
|
49 |
+
<tbody
|
50 |
+
<table>
|
51 |
+
<tbody>
|
52 |
+
<tr>
|
53 |
+
<td>
|
54 |
+
<audio controls="" preload="none" style="width: 200px">
|
55 |
+
audio not supported
|
56 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk1/0.wav" type="audio/wav">
|
57 |
+
</audio>
|
58 |
+
</td>
|
59 |
+
<td>
|
60 |
+
<audio controls="" preload="none" style="width: 200px">
|
61 |
+
audio not supported
|
62 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk1/0.wav" type="audio/wav"">
|
63 |
+
</audio>
|
64 |
+
</td>
|
65 |
+
<td>
|
66 |
+
<audio controls="" preload="none" style="width: 200px">
|
67 |
+
audio not supported
|
68 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk1/0.wav" type="audio/wav">
|
69 |
+
</audio>
|
70 |
+
</td>
|
71 |
+
</tr>
|
72 |
+
<tr>
|
73 |
+
<td>
|
74 |
+
<audio controls="" preload="none" style="width: 200px">
|
75 |
+
audio not supported
|
76 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk1/1.wav" type="audio/wav">
|
77 |
+
</audio>
|
78 |
+
</td>
|
79 |
+
<td>
|
80 |
+
<audio controls="" preload="none" style="width: 200px">
|
81 |
+
audio not supported
|
82 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk1/1.wav" type="audio/wav">
|
83 |
+
</audio>
|
84 |
+
</td>
|
85 |
+
<td>
|
86 |
+
<audio controls="" preload="none" style="width: 200px">
|
87 |
+
audio not supported
|
88 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk1/1.wav" type="audio/wav">
|
89 |
+
</audio>
|
90 |
+
</td>
|
91 |
+
</tr>
|
92 |
+
<tr>
|
93 |
+
<td>
|
94 |
+
<audio controls="" preload="none" style="width: 200px">
|
95 |
+
audio not supported
|
96 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk1/2.wav" type="audio/wav">
|
97 |
+
</audio>
|
98 |
+
</td>
|
99 |
+
<td>
|
100 |
+
<audio controls="" preload="none" style="width: 200px">
|
101 |
+
audio not supported
|
102 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk1/2.wav" type="audio/wav">
|
103 |
+
</audio>
|
104 |
+
</td>
|
105 |
+
<td>
|
106 |
+
<audio controls="" preload="none" style="width: 200px">
|
107 |
+
audio not supported
|
108 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk1/2.wav" type="audio/wav">
|
109 |
+
</audio>
|
110 |
+
</td>
|
111 |
+
</tr>
|
112 |
+
</tbody>
|
113 |
+
</table>
|
114 |
+
|
115 |
+
* Mostres masculines:
|
116 |
+
|
117 |
+
<table style="font-size:16px">
|
118 |
+
<col width="205">
|
119 |
+
<col width="205">
|
120 |
+
<thead>
|
121 |
+
<tr>
|
122 |
+
<td>Valencià</td>
|
123 |
+
<td>Nord-Occidental</td>
|
124 |
+
<td>Balear</td>
|
125 |
+
</tr>
|
126 |
+
</thead>
|
127 |
+
<tbody
|
128 |
+
<table>
|
129 |
+
<tbody>
|
130 |
+
<tr>
|
131 |
+
<td>
|
132 |
+
<audio controls="" preload="none" style="width: 200px">
|
133 |
+
audio not supported
|
134 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk0/0.wav" type="audio/wav">
|
135 |
+
</audio>
|
136 |
+
</td>
|
137 |
+
<td>
|
138 |
+
<audio controls="" preload="none" style="width: 200px">
|
139 |
+
audio not supported
|
140 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk0/0.wav" type="audio/wav"">
|
141 |
+
</audio>
|
142 |
+
</td>
|
143 |
+
<td>
|
144 |
+
<audio controls="" preload="none" style="width: 200px">
|
145 |
+
audio not supported
|
146 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk0/0.wav" type="audio/wav">
|
147 |
+
</audio>
|
148 |
+
</td>
|
149 |
+
</tr>
|
150 |
+
<tr>
|
151 |
+
<td>
|
152 |
+
<audio controls="" preload="none" style="width: 200px">
|
153 |
+
audio not supported
|
154 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk0/1.wav" type="audio/wav">
|
155 |
+
</audio>
|
156 |
+
</td>
|
157 |
+
<td>
|
158 |
+
<audio controls="" preload="none" style="width: 200px">
|
159 |
+
audio not supported
|
160 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk0/1.wav" type="audio/wav">
|
161 |
+
</audio>
|
162 |
+
</td>
|
163 |
+
<td>
|
164 |
+
<audio controls="" preload="none" style="width: 200px">
|
165 |
+
audio not supported
|
166 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk0/1.wav" type="audio/wav">
|
167 |
+
</audio>
|
168 |
+
</td>
|
169 |
+
</tr>
|
170 |
+
<tr>
|
171 |
+
<td>
|
172 |
+
<audio controls="" preload="none" style="width: 200px">
|
173 |
+
audio not supported
|
174 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/valencia/spk0/2.wav" type="audio/wav">
|
175 |
+
</audio>
|
176 |
+
</td>
|
177 |
+
<td>
|
178 |
+
<audio controls="" preload="none" style="width: 200px">
|
179 |
+
audio not supported
|
180 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/occidental/spk0/2.wav" type="audio/wav">
|
181 |
+
</audio>
|
182 |
+
</td>
|
183 |
+
<td>
|
184 |
+
<audio controls="" preload="none" style="width: 200px">
|
185 |
+
audio not supported
|
186 |
+
<source src="https://github.com/mllopartbsc/assets/raw/c6a393237e712851dd7cc7d10c70dde29d3412ac/matcha_tts_catalan/balear/spk0/2.wav" type="audio/wav">
|
187 |
+
</audio>
|
188 |
+
</td>
|
189 |
+
</tr>
|
190 |
+
</tbody>
|
191 |
+
</table>
|
192 |
+
|
193 |
+
## Components principals
|
194 |
+
|
195 |
+
El nostre model de text-a-veu adaptat per al català utilitza un procés amb diferentes etapes per a convertir el text escrit en paraules parlades de pronunciació precisa. Aquestes són les etapes:
|
196 |
+
|
197 |
+
1- Inicialment, el model analitza el text d'entrada, descomposant-lo en unitats lingüístiques més petites com ara paraules i frases. També, identifica qualsevol caràcter especial. A continuació, utilitza la nostra versió d'eSpeak, un fonemitzador de parla, per generar fonemes basats en les regles fonètiques de la llengua catalana. Per a cada accent català, s'apliquen certes regles d'eSpeak específicament adaptades.
|
198 |
+
|
199 |
+
2- El model matcha-TTS converteix aquests fonemes en un espectrograma mel, una representació visual de l'espectre de freqüències d'un so al llarg del temps.
|
200 |
+
|
201 |
+
3- Després, aquest espectrograma s'afegeix com a input a [la nostra adaptació del vocoder Vocos,](https://huggingface.co/BSC-LT/vocos-mel-22khz-cat), que sintetitza l'ona sonora.
|
202 |
+
|
203 |
+
Emprant aquesta sèrie d'etapes, el model de TTS assegura una pronunciació precisa i un discurs en català de so natural adaptat als matisos de la llengua. El còmput d'aquestes etapes va ser realitzat pel Marenostrum 5 del Centre Nacional de Supercomputació de Barcelona, i pel Finisterrae III de CESGA.
|
204 |
+
|
205 |
+
Junts, aquestes tecnologies formen una solució TTS completa, adaptada a les necessitats dels parlants de català i exemplificant el poder de les iniciatives de codi obert per avançar en la diversitat lingüística i la inclusió.
|
206 |
+
|
207 |
+
## El model en detall
|
208 |
+
|
209 |
+
**Matcha-TTS** és una arquitectura de codificador-decodificador dissenyada per a una modelització acústica ràpida en TTS.
|
210 |
+
D'una banda, la part del codificador es basa en un codificador de text i una predicció de duració fonèmica. Junts, prediuen una mitja de les característiques acústiques.
|
211 |
+
D'altra banda, el decodificador té bàsicament un esquelet U-Net inspirat en [Grad-TTS](https://arxiv.org/pdf/2105.06337.pdf), que es basa en l'arquitectura Transformer.
|
212 |
+
En aquest últim, substituint CNNs 2D per CNNs 1D, s'aconsegueix una gran reducció en el consum de memòria i una síntesi ràpida.
|
213 |
+
|
214 |
+
**Matcha-TTS** és un model no autoregressiu entrenat amb emparellament de flux condicional d'optimització de transport (OT-CFM).
|
215 |
+
Això produeix un decodificador basat en ODE capaç de generar una alta qualitat de sortida en menys passos de síntesi que els models entrenats utilitzant score matching.
|
216 |
+
|
217 |
+
## Adaptació al català
|
218 |
+
|
219 |
+
El model original de Matcha-TTS excel·leix en anglès, però per portar les seves capacitats al català, es va dur a terme un procés multi-etapa. En primer lloc, vam ajustar el model d'anglès a català central, el que va establir les bases per entendre els matisos del llenguatge. Aquest primer ajust es va fer utilitzant dos conjunts de dades:
|
220 |
+
|
221 |
+
* [La nostra versió del conjunt de dades openslr-slr69.](https://huggingface.co/datasets/projecte-aina/openslr-slr69-ca-trimmed-denoised)
|
222 |
+
|
223 |
+
* Un conjunt de dades en català central, enregistrades en estudi i que aviat es publicaran.
|
224 |
+
|
225 |
+
* [La nostra versió del conjunt de dades Festcat.](https://huggingface.co/datasets/projecte-aina/festcat_trimmed_denoised)
|
226 |
+
|
227 |
+
Aquest conjunt de dades que aviat es publicarà també incloïa gravacions de tres dialectes diferents:
|
228 |
+
|
229 |
+
* Balear
|
230 |
+
|
231 |
+
* Nord-Occidental
|
232 |
+
|
233 |
+
* Valencià
|
234 |
+
|
235 |
+
Amb un locutor masculí i un femení per a cada dialecte.
|
236 |
+
|
237 |
+
Després, mitjançant l'ajustament per a aquests dialectes catalans específics, el model es va adaptar a les variacions regionals de pronunciació i cadència. Aquest enfocament meticulós garanteix que el model reflecteixi la riquesa lingüística i la diversitat cultural dins de la comunitat de parla catalana, oferint una comunicació fluida entre dialectes que prèviament no comptaven amb aquestes tecnologies.
|
238 |
+
|
239 |
+
A més de l'entrenament del model Matcha-TTS per al català, la integració del fonemitzador d'eSpeak va jugar un paper crucial en millorar la naturalitat i l'exactitud de la parla generada. Un sistema TTS consta de diversos components, cadascun dels quals contribueix a la qualitat global de la parla sintetitzada. El primer component implica el pre-processament de text, on el text d'entrada s'normalitza i s'analitza lingüísticament per identificar paraules, puntuació i característiques lingüístiques. A continuació, el text es converteix en fonemes, les unitats més petites de so en una llengua, a través d'un procés anomenat fonemització. Aquest pas és on el fonemitzador d'eSpeak destaca, ja que converteix amb precisió el text català en representacions fonètiques, capturant els subtils matisos de pronunciació específics del català. Podeu trobar la versió d'eSpeak que vam utilitzar [aquí](https://github.com/projecte-aina/espeak-ng/tree/dev-ca).
|
240 |
+
|
241 |
+
Després de la fonemització, els fonemes es passen al component de síntesi, on es transformen en parla audible. Aquí, el model Matxa pren protagonisme, generant una parla fluida i natural a partir de les representacions fonèmiques. L'ús d'un model de TTS entrenat específicament per al català, juntament amb el fonemitzador d'eSpeak, assegura una pronunciació precisa i una parla coherent, capturant la riquesa i la diversitat del català en tots els seus dialectes i varietats.
|
242 |
+
|
243 |
+
Finalment, el discurs sintetitzat passa per un post-processament, on s'apliquen característiques prosòdiques com el to, la durada i l'èmfasi per refinar encara més la sortida i fer-la sonar més natural i expressiva. Integrant el fonemitzador d'eSpeak en el flux de treball del TTS i adaptant-lo al català, juntament amb l'entrenament del model Matcha-TTS per al català, hem creat un sistema complet i efectiu per generar parla catalana de alta qualitat. Aquesta combinació de tècniques avançades i atenció meticulosa als detalls lingüístics és instrumental per superar les barreres lingüístiques i facilitar la comunicació per als parlants de català arreu del món.
|
244 |
+
|
245 |
+
## Citació
|
246 |
+
|
247 |
+
Si feu servir el model per a la vostra recerca o projecte, us agrairíem que citessiu el següent paper:
|
248 |
+
|
249 |
+
```
|
250 |
+
@misc{LTU2024,
|
251 |
+
title={Natural and efficient TTS in Catalan: using Matcha-TTS with the Catalan language},
|
252 |
+
author={The Language Technologies Unit from Barcelona Supercomputing Center},
|
253 |
+
year={2024},
|
254 |
+
}
|
255 |
+
```
|
256 |
+
```
|
257 |
+
@misc{mehta2024matchatts,
|
258 |
+
title={Matcha-TTS: A fast TTS architecture with conditional flow matching},
|
259 |
+
author={Shivam Mehta and Ruibo Tu and Jonas Beskow and Éva Székely and Gustav Eje Henter},
|
260 |
+
year={2024},
|
261 |
+
eprint={2309.03199},
|
262 |
+
archivePrefix={arXiv},
|
263 |
+
primaryClass={eess.AS}
|
264 |
+
}
|
265 |
+
```
|
266 |
+
|
267 |
+
## Informació addicional
|
268 |
+
|
269 |
+
### Autor
|
270 |
+
Unitat de Tecnologies del Llenguatge del Centre Nacional de Supercomputació de Barcelona.
|
271 |
+
|
272 |
+
### Contacte
|
273 |
+
Per a més informació, si us plau, envia un correu electrònic a <langtech@bsc.es>.
|
274 |
+
|
275 |
+
### Copyright
|
276 |
+
Copyright(c) 2023 by Language Technologies Unit, Barcelona Supercomputing Center.
|
277 |
+
|
278 |
+
### Llicència
|
279 |
+
[Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0)
|
280 |
+
|
281 |
+
### Finançament
|
282 |
+
Aquest treball ha estat promogut i finançat per la Generalitat de Catalunya a través del [Projecte Aina](https://projecteaina.cat/).
|