đ SpeechT5 (voice conversion task)
A fine - tuned SpeechT5 model for voice conversion (speech - to - speech) on CMU ARCTIC.
This model addresses the need for high - quality voice conversion, leveraging the power of the SpeechT5 architecture to transform one voice into another effectively.
đ Quick Start
Use the code below to convert a mono 16 kHz speech waveform into another.
from transformers import SpeechT5Processor, SpeechT5ForSpeechToSpeech, SpeechT5HifiGan
from datasets import load_dataset
dataset = load_dataset("hf-internal-testing/librispeech_asr_demo", "clean", split="validation")
dataset = dataset.sort("id")
sampling_rate = dataset.features["audio"].sampling_rate
example_speech = dataset[0]["audio"]["array"]
processor = SpeechT5Processor.from_pretrained("microsoft/speecht5_vc")
model = SpeechT5ForSpeechToSpeech.from_pretrained("microsoft/speecht5_vc")
vocoder = SpeechT5HifiGan.from_pretrained("microsoft/speecht5_hifigan")
inputs = processor(audio=example_speech, sampling_rate=sampling_rate, return_tensors="pt")
import numpy as np
import torch
speaker_embeddings = np.load("xvector_speaker_embedding.npy")
speaker_embeddings = torch.tensor(speaker_embeddings).unsqueeze(0)
speech = model.generate_speech(inputs["input_values"], speaker_embeddings, vocoder=vocoder)
import soundfile as sf
sf.write("speech.wav", speech.numpy(), samplerate=16000)
⨠Features
- Unified - Modal Framework: Motivated by the success of T5 in pre - trained natural language processing models, the SpeechT5 framework explores encoder - decoder pre - training for self - supervised speech/text representation learning. It consists of a shared encoder - decoder network and six modal - specific (speech/text) pre/post - nets.
- Cross - Modal Vector Quantization: To align textual and speech information into a unified semantic space, a cross - modal vector quantization approach is proposed, which randomly mixes up speech/text states with latent units as the interface between encoder and decoder.
- Versatile Performance: Extensive evaluations show its superiority on a wide variety of spoken language processing tasks, including automatic speech recognition, speech synthesis, speech translation, voice conversion, speech enhancement, and speaker identification.
đ Documentation
Model Description
Motivated by the success of T5 (Text - To - Text Transfer Transformer) in pre - trained natural language processing models, we propose a unified - modal SpeechT5 framework that explores the encoder - decoder pre - training for self - supervised speech/text representation learning. The SpeechT5 framework consists of a shared encoder - decoder network and six modal - specific (speech/text) pre/post - nets. After preprocessing the input speech/text through the pre - nets, the shared encoder - decoder network models the sequence - to - sequence transformation, and then the post - nets generate the output in the speech/text modality based on the output of the decoder.
Leveraging large - scale unlabeled speech and text data, we pre - train SpeechT5 to learn a unified - modal representation, hoping to improve the modeling capability for both speech and text. To align the textual and speech information into this unified semantic space, we propose a cross - modal vector quantization approach that randomly mixes up speech/text states with latent units as the interface between encoder and decoder.
Extensive evaluations show the superiority of the proposed SpeechT5 framework on a wide variety of spoken language processing tasks, including automatic speech recognition, speech synthesis, speech translation, voice conversion, speech enhancement, and speaker identification.
Intended Uses & Limitations
You can use this model for speech conversion. See the model hub to look for fine - tuned versions on a task that interests you.
Currently, both the feature extractor and model support PyTorch.
đ License
The license used is MIT.
đ Citation
BibTeX:
@inproceedings{ao-etal-2022-speecht5,
title = {{S}peech{T}5: Unified-Modal Encoder-Decoder Pre-Training for Spoken Language Processing},
author = {Ao, Junyi and Wang, Rui and Zhou, Long and Wang, Chengyi and Ren, Shuo and Wu, Yu and Liu, Shujie and Ko, Tom and Li, Qing and Zhang, Yu and Wei, Zhihua and Qian, Yao and Li, Jinyu and Wei, Furu},
booktitle = {Proceedings of the 60th Annual Meeting of the Association for Computational Linguistics (Volume 1: Long Papers)},
month = {May},
year = {2022},
pages={5723--5738},
}
Property |
Details |
Model Type |
SpeechT5 fine - tuned for voice conversion |
Training Data |
CMU ARCTIC |