/DCNN

Implementation of Deep Dilated Convolutional Networks for GCI Detection

Primary LanguagePython

DCNN

Python 3.6 PyTorch 1.0

Code for Detection of Glottal Closure Instants using Deep Dilated Convolutional Neural Networks [Paper]

Published in INTERSPEECH-2019 (poster)

Authors: Mohit Goyal*, Varun Srivastava*, Prathosh A.P.

* Equal Contribution

State of the art results on GCI detection

The proposed algorithm CNN demonstrates best performance across speakers, noise types and noise SNRs

Abstract

Glottal Closure Instants (GCIs) correspond to the temporal locations of significant excitation to the vocal tract occurring during the production of voiced speech. GCI detection from speech signals is a well-studied problem given its importance in speech processing. Most of the existing approaches for GCI detection adopt a two-stage approach (i) Transformation of speech signal into a representative signal where GCIs are localized better, (ii) extraction of GCIs using the representative signal obtained in first stage. The former stage is accomplished using signal processing techniques based on the principles of speech production and the latter with heuristic-algorithms such as dynamic-programming and peak-picking. These methods are thus task-specific and rely on the methods used for representative signal extraction. However, in this paper, we formulate the GCI detection problem from a representation learning perspective where appropriate representation is implicitly learned from the raw-speech data samples. Specifically, GCI detection is cast as a supervised multi-task learning problem solved using a deep convolutional neural network jointly optimizing a classification and regression cost. The learning capability is demonstrated with several experiments on standard datasets. The results compare well with the state-of-the-art algorithms while performing better in the case of presence of real-world non-stationary noise.

Dataset

The given code has been tested on the CMU Arctic Dataset for the speakers BDL, JMK, SLT available online at CMU Database

Requirements

  1. Python 3.6 or greater
  2. Pytorch (GPU/CPU) GPU highly recommended

Running Experiments

All source files have been written in python, with the exception of minor utility scripts written in bash. They are not required for running the training code. The broad codebase can be divided into the following three parts:

  • Preprocessing
  • Training and Validation
  • Visualization

The pipeline for each part is explained below.

Preprocessing

Training and Validation

The file main.py is the entry-point to the training procedure. A complete configuration of the training hyperparameters and configuration may be found in function config in main.py. A sample invocation of the training procedure would look like

python main.py 

It is important to set the configuration parameters speech_npz_file and egg_npz_file containing the path to the speech and egg files. It is currently set to files example_speech.npz and example_egg.npz for illustrative purposes. These files area available at the google drive link Drive Link

Functional flowchart of a single forward pass (prediction)

Visualization

Histogram Clustering of the predictions made by the CNN