--- license: mit datasets: - styletts2-community/multilingual-phonemes-10k-alpha language: - fr - en - es - ca - de - el - fa - fi - pt - pl - ru - sv - uk - zh --- # Multilingual PL-BERT checkpoint The checkpoint open-sourced here is trained by Papercup using the open-source PL-BERT model found here https://github.com/yl4579/PL-BERT. It is trained to be supported by StyleTTS2, which can be found here: https://github.com/yl4579/StyleTTS2. You can see in the model card the languages that it has been trained on (the languages correspond to the crowdsourced dataset found here https://huggingface.co/datasets/styletts2-community/multilingual-phonemes-10k-alpha). Notable differences compared to the default PL-BERT checkpoint and config available [here](https://github.com/yl4579/StyleTTS2/tree/main/Utils/PLBERT): * Because we are working with many languages, we are using a different tokenizer now: `bert-base-multilingual-cased`. * The PL-BERT model was trained on the data obtained from `styletts2-community/multilingual-phonemes-10k-alpha` for 1.1M iterations. * The `token_maps.pkl` file has changed (also open-sourced here). * We have changed the `util.py` file to deal with an error when loading `new_state_dict["embeddings.position_ids"]`. ## How do I train StyleTTS2 with this new PL-BERT checkpoint? * Simply create a new folder under `Utils` in your StyleTTS2 repository. Call it, for example, `PLBERT_all_languages`. * Copy paste into it `config.yml`, `step_1100000.t7` and `util.py`. * Then, in your StyleTTS2 config file, change `PLBERT_dir` to `Utils/PLBERT_all_languages`. You will also need to change your import as such: * Change `from Utils.PLBERT.util import load_plbert` * To `from Utils.PLBERT_all_languages.util import load_plbert` * Alternatively, you can just replace the relevant files in `Utils/PLBERT` and not have to change any code. * Now, you need to create train and validation files. You will need to use `espeak` to create a file in the same format as the ones that exist in the `Data` folder of the StyleTTS2 repository. Careful! You will need to change the `language` argument to phonemise your text if it's not in English. You can find the correct language codes [here](https://github.com/espeak-ng/espeak-ng/blob/master/docs/languages.md). For example, Latin American Spanish is `es-419` Voila, you can now train a multilingual StyleTTS2 model! Thank you to Aaron (Yinghao) Li for these contributions.