Skip to main content

Trains CNN classifiers from raw speech using Keras and tests them.

Project description

Raw Speech Classification

PyPI package

Trains CNN (or any neural network based) classifiers from raw speech using Keras and tests them. The inputs are lists of wav files, where each file is labelled. It then creates fixed length signals and processes them. During testing, it computes scores at the utterance or speaker levels by averaging the corresponding frame-level scores from the fixed length signals.

Installation

Installing from PyPI

If you want to install the last release of this package in your current environment (we recommend using Conda to manage virtual environments, e.g. to have a specific version of Python), you can run either of the following commands, depending on your desired framework:

pip install raw-speech-classification[torch]

or

pip install raw-speech-classification[tensorflow]

or

pip install raw-speech-classification[jax]

If you already have an environment with PyTorch, TensorFlow, or Jax installed, you can simply run:

pip install raw-speech-classification

Installing from source in a virtual environment

To install the following repository from source, clone this repository, then run (according to the Keras backend you desire):

pip install -e .[torch]

or

pip install -e .[tensorflow]

or

pip install -e .[jax]

You will also need to set the KERAS_BACKEND environment variable to the correct backend before running rsclf-train or rsclf-test (see below), or globally for the current bash session with:

export KERAS_BACKEND=torch

Replace torch by tensorflow or jax accordingly.

Using the code

  1. Create lists for training, cross-validation and testing. Each line in a list must contain the path to a wav file (relative to the -R or --root option), followed by its integer label indexed from 0, separated by a space. E.g. if your data files are in /home/bob/data/my_dataset/part*/file*.wav, the root option could be /home/bob/data/my_dataset and the content of the files would then be like:

    part1/file1.wav 1
    part1/file2.wav 0
    

    Full list files for IEMOCAP are available in the repository as example in datasets/IEMOCAP/F1_lists.

  2. You can now run the following commands (use the --help option of each command to get more details):

    rsclf-wav2feat --wav-list-file list_files/cv.list --feature-dir output/cv_feat --mode train --root path/to/dataset/basedir
    rsclf-wav2feat --wav-list-file list_files/train.list --feature-dir output/train_feat --mode train --root path/to/dataset/basedir
    rsclf-wav2feat --wav-list-file list_files/test.list --feature-dir output/test_feat --mode test --root path/to/dataset/basedir
    KERAS_BACKEND=torch rsclf-train --train-feature-dir output/train_feat --validation-feature-dir output/cv_feat --output-dir output/cnn_subseg --arch subseg --splice-size 25 --verbose 2
    KERAS_BACKEND=torch rsclf-test --feature-dir output/test_feat --model-filename output/cnn_subseg/cnn.keras --output-dir output/cnn_subseg --splice-size 25 --verbose 0
    rsclf-plot --output-dir output/ output/cnn_subseg
    

Using run.sh (only with Conda)

run.sh allows to run all these steps in one command when using Conda as virtual environment manager. This examples shows how to use the IEMOCAP lists shipped in the repository:

bash run.sh -C ~/miniforge3 -n rscl -D datasets/IEMOCAP/F1_lists -a seg -o results/seg-f1 -R <IEMOCAP_DATA_ROOT>

Replace <IEMOCAP_DATA_ROOT> by the path to the IEMOCAP data directory containing IEMOCAP_full_release/Session*.

Here is an example of the log printed to the terminal, and you should obtain the following curve in results/seg-f1/plot.png:

Results

Code components

  1. wav2feat.py creates directories where the wav files are stored as fixed length frames for faster access during training and testing.

  2. train.py is the Keras training script.

  3. Model architecture can be configured in model_architecture.py.

  4. rawdataset.py provides an object that reads the saved directories in batches and retrieves mini-batches for training.

  5. test.py performs the testing and generates scores as posterior probabilities. If you need the results per speaker, configure it accordingly (see the script for details). The default output format is:

     <speakerID> <label> [<posterior_probability_vector>]
    
  6. plot.py generates and saves the learning curves.

Training schedule

The script uses stochastic gradient descent with 0.5 momentum. It starts with a learning rate of 0.1 for a minimum of 5 epochs. Whenever the validation loss reduces by less than 0.002 between successive epochs, the learning rate is halved. Halving is performed until the learning rate reaches 1e-7.

Contributors

Idiap Research Institute

Authors: S. Pavankumar Dubagunta and Dr. Mathew Magimai-Doss

License

GNU GPL v3

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

raw_speech_classification-1.0.4.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

raw_speech_classification-1.0.4-py3-none-any.whl (26.6 kB view details)

Uploaded Python 3

File details

Details for the file raw_speech_classification-1.0.4.tar.gz.

File metadata

File hashes

Hashes for raw_speech_classification-1.0.4.tar.gz
Algorithm Hash digest
SHA256 df1e0c1e57f37bc8cb9eeec53e2dac0d40cc2e7e0d86c7ee9d10c2d4c5dcfc6a
MD5 05e9a18858c5e840d9363b4e92160616
BLAKE2b-256 7e195ff46c856b35d7f90812878cc80a6057981c430daedd400ab5e185638be5

See more details on using hashes here.

Provenance

The following attestation bundles were made for raw_speech_classification-1.0.4.tar.gz:

Publisher: deploy.yml on idiap/RawSpeechClassification

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file raw_speech_classification-1.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for raw_speech_classification-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7918022d893e85d410d920d6dc7cfb7276172b65fd7dd6cfe842062ac306b1e9
MD5 9e5f6b297a079fdb8111b1b87ee2915a
BLAKE2b-256 c1f359a20e7bd19e115781d7e54d3b59e68c47cfe55629ebd7d1366fdad02ade

See more details on using hashes here.

Provenance

The following attestation bundles were made for raw_speech_classification-1.0.4-py3-none-any.whl:

Publisher: deploy.yml on idiap/RawSpeechClassification

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page