Skip to content

Scalable creation of audio datasets for generating stem continuations of music files

License

Notifications You must be signed in to change notification settings

energydrink9/stem_continuation_dataset_generator

Folders and files

NameName
Last commit message
Last commit date
Nov 25, 2024
Nov 25, 2024
Dec 19, 2024
Nov 21, 2024
Nov 21, 2024
Nov 26, 2024
Nov 21, 2024
Nov 26, 2024
Nov 26, 2024
Nov 26, 2024
Nov 21, 2024

Repository files navigation

example workflow

This application implements a pipeline that can be used to create audio datasets for the generation of stem continuations of music audio files. The code uses Dask in order to scale the dataset processing on a cluster of virtual machines in the cloud. The application is configured to run on AWS EC2 and to use S3 as storage. The audio files are encoded using Meta's Encodec into a discrete, compressed, tokenized representation. Finally, the last step uploads the dataset to ClearML to be used for training and/or inference.

The dataset generation pipeline is comprised of several steps:

  • Uncompress. The application expects to find the stem files for a single music file (in .wav format) in a compressed zip archive. Each stem should have a predefined name in order to be identified as a guitar, bass, drum, etc.
  • Convert to ogg. Conversion of wav files to the Ogg Opus audio format.
  • Merge. Several different assortments of stems are generated.
  • Augment. Audio augmentations are used to increase the dataset size, by changing pitch and tempo.
  • Distort. Several audio distortions are applied to simulate real conditions.
  • Encode. The audio files are encoded using Encodec and chunked.
  • Upload. (Optional) Upload the dataset to ClearML.

Initial setup

In order to start using the application, make sure to run the following commands that will install the package and the necessary dependencies.

pip install poetry
poetry install

Environment Variables

In case you'd like to upload the dataset to ClearML, make sure the following environment variables are set before running the upload step (replace the <> tokens with the actual secrets):

export CLEARML_API_ACCESS_KEY=<YOUR_CLEARML_API_ACCESS_KEY_HERE>
export CLEARML_API_SECRET_KEY=<YOUR_CLEARML_API_SECRET_KEY_HERE>

When running the encode step locally on Apple Silicon, you will also need to set the following environment variable:

export PYTORCH_ENABLE_MPS_FALLBACK=1

Install

poetry install

Dataset generation

Source directory should contain a folder for each artist. The artist folders should contain one compressed file for each song. The compressed file should contain one .wav file for each stem. In order to identify the different stems, the stem files should have names containing the values present at src/stem_continuation_dataset_generator/steps/merge.py in the STEM_NAMES variable.

Dataset preparation

To prepare the dataset, use the following command, replacing the string with the path to the directory containing the source files:

poetry run python -m stem_continuation_dataset_generator.prepare <SOURCE-DIRECTORY>

The pipeline will uncompress the song archives and convert all the files to OGG format. The original files will be deleted and the prepared dataset will be uploaded to the ClearML repository.

Dataset creation

To process the files obtained at the preparation step, use the following command, replacing the string <STEM_NAME> with the name of the stem (musical instrument) for which you want to generate the dataset (i.e. guitar or drum):

poetry run python -m stem_continuation_dataset_generator.process <STEM_NAME>

The pipeline will augment, distort, encode and split the samples into chunks, generating three different folders for the train, validation and test sets. The result will be uploaded to ClearML into 3 different datasets.

Development

Download the repository and install the package:

git clone https://github.com/energydrink9/stem_continuation_dataset_generator.git
cd stem_continuation_dataset_generator
poetry install

Once you've downloaded the repository and installed the package, please run the following command to setup the pre-commit hooks:

pre-commit install

Please run the tests before submitting a PR:

pytest