Skip to content

A lightweight pure C++ Text-to-Speech (TTS) pipeline with OpenVINO, supporting multiple languages.

License

Notifications You must be signed in to change notification settings

apinge/MeloTTS.cpp

Repository files navigation

MeloTTS.cpp

< English | 简体中文 | 繁體中文 >

This repository offers a C++ implementation of meloTTS, which is a high-quality, multilingual Text-to-Speech (TTS) library released by MyShell.ai that supports English, Chinese (mixed with English), and various other languages. This implementation is fully integrated with OpenVINO, supporting seamless deployment on CPU, GPU, and NPU devices. Currently, this repository supports both Chinese with mixed English and English. Support for Japanese model is coming next.

TTS for Chinese with Mixed English

This branch focuses on text-to-speech (TTS) solutions tailored for Chinese mixed with English.

Need Multilingual Support?

If you're looking for TTS solutions for multiple languages, you can switch to the multilang-develop branch.

To switch, run:

git fetch --all
git checkout multilang-develop

For more details, you can visit the MeloTTS.cpp for Multilanguage branch

Pipeline Design

The pipeline design is largely consistent with the orignal pytorch Version, comprising three models (BERT, TTS, and DeepFilterNet), with DeepFilterNet added as an additional component.

Pipeline Design

Legend / Terminology

  1. tokenizer and BERT: The tokenizer and BERT model are bert-base-multilingual-uncased for Chinese and bert-base-uncased for English
  2. g2p: Grapheme-to-Phoneme conversion
  3. phones and tones: represented as pinyin with four tones for Chinese and phonemes with stress marks for English
  4. tone_sandi: class used for handling Chinese scenarios, correcting tokenization and phones
  5. DeepFilterNet: used for denoising (background noise introduced by int8 quantization)

Model-Device Compatibility Table

The table below outlines the supported devices for each model:

Model Name CPU Support GPU Support NPU Support
BERT (Preprocessing)
TTS (Inference)
DeepFilterNet (Post-processing)

Setup and Execution Guide

1. Download OpenVINO C++ Package

To download the OpenVINO C++ package for Windows, please refer to the following link: Install OpenVINO for Windows. For OpenVINO 2024.5 on Windows, you can run the command line in the command prompt (cmd).

curl -O https://storage.openvinotoolkit.org/repositories/openvino/packages/2024.5/windows/w_openvino_toolkit_windows_2024.5.0.17288.7975fa5da0c_x86_64.zip --ssl-no-revoke
tar -xvf w_openvino_toolkit_windows_2024.5.0.17288.7975fa5da0c_x86_64.zip

For Linux, you can download the C++ package from this link: Install OpenVINO for Linux. For OpenVINO 2024.5 on Linux, simply download it from https://storage.openvinotoolkit.org/repositories/openvino/packages/2024.5/linux and unzip the package.

For additional versions and more information about OpenVINO, visit the official OpenVINO Toolkit page: OpenVINO Toolkit Overview.

2. Clone the Repository

git lfs install
git clone https://github.com/apinge/MeloTTS.cpp.git

3. Build and Run

3.1 Windows Build and Run

<OpenVINO_DIR>\setupvars.bat
cd MeloTTS.cpp
cmake -S . -B build && cmake --build build --config Release
.\build\Release\meloTTS_ov.exe --model_dir ov_models --input_file inputs.txt  --output_file audio.wav

3.2 Linux Build and Run

source <OpenVINO_DIR>/setupvars.sh
cd MeloTTS.cpp 
cmake -S . -B build && cmake --build build --config Release
./build/meloTTS_ov --model_dir ov_models --input_file inputs.txt --output_file audio.wav

3.3 Enabling and Disabling DeepFilterNet

DeepFilterNet functionality is currently supported only on Windows and is used to filter noise from int8 quantized models. By default, it is enabled, but you can enable or disable it during the CMake stage using the -DUSE_DEEPFILTERNET option.

For example, to disable the feature, you can use the following line during the CMake generation process:

cmake -S . -B build -DUSE_DEEPFILTERNET=OFF

For more information, please refer to DeepFilterNet.cpp.

4. Arguments Description

You can use run_tts.bat or run_tts.sh as sample scripts to run the models. Below are the meanings of all the arguments you can use with these scripts:

  • --model_dir: Specifies the folder containing the model files, dictionary files, and third-party resource files, which is ov_models folder within the repo. You may need to adjust the relative path based on your current working directory.
  • --tts_device: Specifies the OpenVINO device to be used for the TTS model. Supported devices include CPU and GPU (default: CPU).
  • --bert_device: Specifies the OpenVINO device to be used for the BERT model. Supported devices include CPU, GPU, and NPU (default: CPU).
  • --nf_device: Specifies the OpenVINO device to be used for the DeepfilterNet model. Supported devices include CPU, GPU, and NPU (default: CPU).
  • --input_file: Specifies the input text file to be processed. Make sure that the text is in UTF-8 format.
  • --output_file: Specifies the output *.wav audio file to be generated.
  • --speed: Specifies the speed of output audio. The default is 1.0.
  • --quantize: Indicates whether to use an int8 quantized model. The default is false, meaning an fp16 model is used by default.
  • --disable_bert: Indicates whether to disable the BERT model inference. The default is false.
  • --disable_nf: Indicates whether to disable the DeepfilterNet model inference (default: false).
  • --language: Specifies the language for TTS. The default language is Chinese (ZH).

NPU Device Support

The BERT and DeepFilterNet models in the pipeline support NPU as the inference device, utilizing the integrated NPUs in Meteor Lake and Lunar Lake.

Below are the methods to enable this feature and the usage details:

Click here to expand/collapse content
  • How to Build
  • To enable the BERT model on NPU, an additional CMake option -DUSE_BERT_NPU=ON is required during the CMake generation. For example:
    cmake -DUSE_BERT_NPU=ON -B build -S .
    To enable DeepFilterNet on NPU, no additional compilation steps are required.
  • How to Set Arguments
  • To set arguments for models on NPU, use --bert_device NPU for the BERT model and --nf_device NPU for the DeepFilterNet model respectively. For example:
    build\Release\meloTTS_ov.exe --bert_device NPU --nf_device NPU --model_dir ov_models --input_file inputs.txt  --output_file audio.wav

Supported Versions

  • Operating System: Windows, Linux
  • CPU Architecture: Metor Lake, Lunar Lake, and most Intel CPUs
  • GPU Architecture: Intel® Arc™ Graphics (Intel Xe, including iGPU)
  • NPU Architecture: NPU 4, NPU in Meteor Lake or Lunar Lake
  • OpenVINO Version: >=2024.4
  • C++ Version: >=C++20

If you're using an AI PC notebook with Windows, GPU and NPU drivers are typically pre-installed. However, Linux users or Windows users who prefer to update to the latest drivers should follow the guidelines below:

Note that all the drivers differs between Windows and Linux, so make sure to follow the instructions for your specific operating system.

Future Development Plan

Here are some features and improvements planned for future releases:

  1. Add Japanese language TTS support:

    • Enable Japanese text-to-speech (TTS) functionality, but tokenization for Japanese language input is not yet implemented.
  2. Enhancing Quality in Quantized TTS Models:

    • The current INT8 quantized model exhibits slight background noise. As a workaround, we integrated DeepFilterNet for post-processing. Moving forward, we aim to address the noise issue more effectively by the quantization techniques.

Python Version

The Python version of this repository (MeloTTS integrated with OpenVINO) is provided in MeloTTS-OV. The Python version includes methods to convert the model into OpenVINO IR.

Third-Party Code

This repository includes third-party code and libraries for Chinese word segmentation and pinyin processing.

  • cppjieba
    • A Chinese text segmentation library.
  • cppinyin
    • A C++ library supporting conversion between Chinese characters and pinyin
  • libtorch
    • Used to integrate DeepFilterNet

About

A lightweight pure C++ Text-to-Speech (TTS) pipeline with OpenVINO, supporting multiple languages.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •