From 119ca724501fcd65d95699de0b370aa00f6f53e1 Mon Sep 17 00:00:00 2001 From: liuyibing01 Date: Mon, 9 Mar 2020 17:53:24 +0000 Subject: [PATCH] Update README & release clarinet model --- README.md | 102 +++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 85 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index aef1963..f83940f 100644 --- a/README.md +++ b/README.md @@ -6,12 +6,31 @@ Parakeet aims to provide a flexible, efficient and state-of-the-art text-to-spee
-In particular, it features the latest [WaveFlow] (https://arxiv.org/abs/1912.01219) model proposed by Baidu Research. +In particular, it features the latest [WaveFlow] (https://arxiv.org/abs/1912.01219) model proposed by Baidu Research. + - WaveFlow can synthesize 22.05 kHz high-fidelity speech around 40x faster than real-time on a Nvidia V100 GPU without engineered inference kernels, which is faster than [WaveGlow] (https://github.com/NVIDIA/waveglow) and serveral orders of magnitude faster than WaveNet. - WaveFlow is a small-footprint flow-based model for raw audio. It has only 5.9M parameters, which is 15x smalller than WaveGlow (87.9M) and comparable to WaveNet (4.6M). - WaveFlow is directly trained with maximum likelihood without probability density distillation and auxiliary losses as used in Parallel WaveNet and ClariNet, which simplifies the training pipeline and reduces the cost of development. -### Setup +## Overview + +In order to facilitate exploiting the existing TTS models directly and developing the new ones, Parakeet selects typical models and provides their reference implementations in PaddlePaddle. Further more, Parakeet abstracts the TTS pipeline and standardizes the procedure of data preprocessing, common modules sharing, model configuration, and the process of training and synthesis. The models supported here includes Vocoders and end-to-end TTS models: + +- Vocoders + - [WaveFlow: A Compact Flow-based Model for Raw Audio](https://arxiv.org/abs/1912.01219) + - [ClariNet: Parallel Wave Generation in End-to-End Text-to-Speech](https://arxiv.org/abs/1807.07281) + - [WaveNet: A Generative Model for Raw Audio](https://arxiv.org/abs/1609.03499) + +- TTS models + - [Deep Voice 3: Scaling Text-to-Speech with Convolutional Sequence Learning](https://arxiv.org/abs/1710.07654) + - [Neural Speech Synthesis with Transformer Network (Transformer TTS)](https://arxiv.org/abs/1809.08895) + - [FastSpeech: Fast, Robust and Controllable Text to Speech](https://arxiv.org/abs/1905.09263) + +And more will be added in the future. + +See the guide for details about how to build your own model and experiment in Parakeet. + +## Setup Make sure the library `libsndfile1` is installed, e.g., on Ubuntu. @@ -21,12 +40,12 @@ sudo apt-get install libsndfile1 ### Install PaddlePaddle -See [install](https://www.paddlepaddle.org.cn/install/quick) for more details. This repo requires paddlepaddle 1.7 or above. +See [install](https://www.paddlepaddle.org.cn/install/quick) for more details. This repo requires PaddlePaddle 1.7.0 or above. ### Install Parakeet ```bash -# git clone this repo first +git clone https://github.com/PaddlePaddle/Parakeet cd Parakeet pip install -e . ``` @@ -34,6 +53,7 @@ pip install -e . ### Install CMUdict for nltk CMUdict from nltk is used to transform text into phonemes. + ```python import nltk nltk.download("punkt") @@ -41,23 +61,71 @@ nltk.download("cmudict") ``` -## Related Research -- [Deep Voice 3: Scaling Text-to-Speech with Convolutional Sequence Learning](https://arxiv.org/abs/1710.07654) -- [Neural Speech Synthesis with Transformer Network](https://arxiv.org/abs/1809.08895) -- [FastSpeech: Fast, Robust and Controllable Text to Speech](https://arxiv.org/abs/1905.09263) -- [WaveFlow: A Compact Flow-based Model for Raw Audio](https://arxiv.org/abs/1912.01219) -- [WaveNet: A Generative Model for Raw Audio](https://arxiv.org/abs/1609.03499) -- [ClariNet: Parallel Wave Generation in End-to-End Text-to-Speech](https://arxiv.org/abs/1807.07281) ## Examples -- [Train a DeepVoice3 model with ljspeech dataset](./examples/deepvoice3) -- [Train a TransformerTTS model with ljspeech dataset](./examples/transformer_tts) -- [Train a FastSpeech model with ljspeech dataset](./examples/fastspeech) -- [Train a WaveFlow model with ljspeech dataset](./examples/waveflow) -- [Train a WaveNet model with ljspeech dataset](./examples/wavenet) -- [Train a Clarinet model with ljspeech dataset](./examples/clarinet) +Entries to the introduction, and the launch of training and synthsis for different example models: + + +- [>>> WaveFlow](./examples/waveflow) +- [>>> Clarinet](./examples/clarinet) +- [>>> WaveNet](./examples/wavenet) +- [>>> Deep Voice 3](./examples/deepvoice3) +- [>>> Transformer TTS](./examples/transformer_tts) +- [>>> FastSpeech](./examples/fastspeech) + + +## Pre-trained models and audio samples + +Parakeet also releases some well-trained parameters for the example models, which can be accessed in the following tables. Each column of these tables lists resources for one model, including the url link to the pre-trained model, the dataset that the model is trained on and the total training steps, and several synthesized audio samples based on the pre-trained model. + +- Vocoders + + + + + + + + + + + + + + + + + + + +
WaveFlowClariNet
LJSpeech, 2MLJSpeech, 500K
+ To be added soon + +
+
+
+
+ +
+ +**Note:** The input samples are drawn from validation dataset that are not visible in training. + +- TTS models + +Click each link to download, then one can get the compressed package which contains the pre-trained model and the `yaml` config describing how to train the model. + ## Copyright and License