Skip to content

suhitaghosh10/ddsp-qbe

Repository files navigation

DDSP-QbE

This repository contains the source code for the paper Anonymising Elderly and Pathological Speech: Voice Conversion Using DDSP and Query-by-Example, accepted at Interspeech 2024.

Concept of our method. For details, refer to our paper at .....

Highlights

  • DDSP-QbE: An end-to-end any-to-any voice conversion (VC) method designed to preserve prosody and domain characteristics in speech anonymization, even for unseen speakers from non-standard data, including pathological (stuttering) and elderly populations.
  • Core Concepts:
    • Query-by-Example (QbE)
    • Differentiable Digital Signal Processing (DDSP)
  • Proposed Approach:
    • Utilizes a subtractive harmonic oscillator-based DDSP synthesizer, inspired by the human speech production model, for effective learning with limited data.
    • Introduces an inductive bias for prosody preservation by:
      • Employing a novel loss function that uses emotional speech to separate prosodic and linguistic features.
      • Adding supplementary hand-crafted and deep learning-generated input features with prosodic knowledge from the source utterance.
  • Generalizability: Demonstrated on the following benchmark datasets across different genders, emotions, ages, pathologies, and cross-corpus conversions:

Samples

Some samples can be found here. Due to privacy concerns, not all samples are available.

Demo

Here...

Pre-requisites

  1. Python >= 3.11

  2. Install the Python dependencies mentioned in requirements.txt:

    conda create --name <environment name> --file requirements.txt
    

Training (Documentation WIP)

Before Training

  1. Download ESD dataset (audio and wavlm representations) from here, and place them at location as mentioned in config.yaml (train_path and val_path).
  2. Configure all the training hyperparameters and paths in resources/config.yaml.
  3. If using the emotion leakage-specific loss:
    • Ensure all WavLM 6th layer embeddings for ESD files are available at the location specified in config.yaml under emotion_files_wavlm6_path.
    • Set use_emo_loss to True in the config file.

Train

To start training, use the following command:

python train.py -g <gpu number> --config ./resources/config.yaml

Model Weights

The model weights are located in resources/model_weights.

References and Acknowledgements

Some portions of the code for this project have been adapted from the following repositories. A big thank you to the authors of:

Notes

In the original paper, the model was trained with ESD and data from Sep28-K and the ADReSS Challenge. However, we have provided an example training script using publicly available datasets due to privacy issues. The pathological datasets can be obtained upon request from their corresponding websites.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published