Skip to content

A pianist identification system based on midi inputs, using convolutional neural networks. (IS2 2023)

License

Notifications You must be signed in to change notification settings

tangjjbetsy/PID-CNN

Repository files navigation

PID-CNN: Pianist Identification Using Convolutional Neural Networks

This repo presents the code implementation for the paper Pianist Identification Using Convolutional Neural Networks

Install the environment pid

Please ensure that you have anaconda installed in you PC.

conda env create -f environment.yaml         

Prepare Data

The alignments data could be found here. Please download the alignment files to folder ./data/ATEPP-alignment. For midi files, please check the ATEPP-dataset repo.

An example of preparing the data:

python data_preprocess.py --mode align --slice_len 1000 -s -o -S

You can set the features in config.py . Features that could be used:

FEATURES_LIST = [
                 'pitch', 
                 'onset_time', 
                 'offset_time',
                 'velocity',
                 'duration',
                 'ioi', #Inter onset interval
                 'otd', #Offset time duration
                 # <----- Deviation Features ----->
                 'onset_time_dev',
                 'offset_time_dev',
                 'velocity_dev',
                 'duration_dev',
                 'ioi_dev',
                 'otd_dev'
                 ]

Please refer to the paper for more details. A full list of options for data processing:

usage: data_preprocess.py [-h] [--path_to_dataset_csv PATH_TO_DATASET_CSV] [--path_to_save PATH_TO_SAVE] [--data_folder DATA_FOLDER] [--score_folder SCORE_FOLDER] [--align_result_column ALIGN_RESULT_COLUMN]
                          [--midi_file_column MIDI_FILE_COLUMN] [--random_state RANDOM_STATE] [--isSplits] [--isSlice] [--isFull] [--isOverlap] [--quantize {score,group,grid,None}] [--max_len MAX_LEN]
                          [--slice_len SLICE_LEN] [--mode {midi,align}]

Argument Parser

options:
  -h, --help            show this help message and exit
  --path_to_dataset_csv PATH_TO_DATASET_CSV
                        Path to dataset CSV file
  --path_to_save PATH_TO_SAVE
                        Path to save processed data
  --data_folder DATA_FOLDER
                        Dictionary to the performances / alignment results
  --score_folder SCORE_FOLDER
                        Dictionary to the scores
  --align_result_column ALIGN_RESULT_COLUMN
                        Column to save the align result file paths
  --midi_file_column MIDI_FILE_COLUMN
                        Column to save the midi performance file paths
  --random_state RANDOM_STATE, -r RANDOM_STATE
                        Random state (default: 42)
  --isSplits, -S        To split the data into train, valid, test sets
  --isSlice, -s         To slice the performances into segments
  --isFull, -f          To use the full performances as input
  --isOverlap, -o       To insert overlap for segments
  --quantize {score,group,grid,None}, -q {score,group,grid,None}
                        To quantize the midi files
  --max_len MAX_LEN, -ml MAX_LEN
                        Maximum lengths for the input (even using the full performances)
  --slice_len SLICE_LEN, -sl SLICE_LEN
                        Segment lengths for slicing
  --mode {midi,align}   Whether to process midi files or alignment files

Training

The training was monitored by with W&B. The current implementation is only compatible with wandb.

For training the models, please run the following commands:

python main.py --mode train

A full list of options for training (and evaluation):

usage: main.py [-h] [--mode {train,evaluate}] [--data_path DATA_PATH] [--num_of_features NUM_OF_FEATURES] [--num_of_performers NUM_OF_PERFORMERS] [--cuda_devices CUDA_DEVICES [CUDA_DEVICES ...]]
               [--save_path SAVE_PATH] [--ckpt_path CKPT_PATH]

options:
  -h, --help            show this help message and exit
  --mode {train,evaluate}
                        Chose to train or evaluate the model.
  --data_path DATA_PATH
                        Path to the processed data file '*.npz'.
  --num_of_features NUM_OF_FEATURES
                        Number of features used in the experiment
  --num_of_performers NUM_OF_PERFORMERS
                        Number of performers considered in the experiment
  --cuda_devices CUDA_DEVICES [CUDA_DEVICES ...]
                        CUDA device ids
  --save_path SAVE_PATH
                        Dictionary to save the evalution report figures. Default to './evaluation/
  --ckpt_path CKPT_PATH
                        Checkpoint path to continue training or evaluate the model.

Evaluating

An example of evaluate the model for performance segments of 1000 notes and using 13 features:

python main.py --mode evaluate --ckpt_path checkpoints/model_best_1000.ckpt

Pre-trained models with different input lengths and number of features are available here. Checkpoints are named by model_best_{SEQUENCE_LEN}_{NUM_FEATURES(if it's NOT 13)}.ckpt.

Inference

An example of using the model checkpoint "model_best_1000_7.ckpt" to inference the identity:

# !!! Remember to modify the FEATURE_LIST in config to match the required features.
# Prepare the data, save to 'data/inference.npy"
python data_preprocess.py --mode midi --max_len 1000 --path_to_midi YOUR_PATH_TO_MIDI
# Inference, load data from "data/inference.npy"
python main.py --ckpt_path checkpoints/model_best_1000_7.ckpt --mode predict --inference_path data/inference.npy

Other Datasets

In this study, we used piano MIDI performances from the ATEPP dataset. However, we have also made attempts on this task with the following datasets:

Maestro-v3.0.0 with performer information

The MAESTRO dataset does not provide information about performers for each performance. We complemented the name and nationality to the meta-data by crawling the website of the International E-Piano Competition and manual verification. Results are provided here.

CHARM Mazurka dataset with cleaned discography

Around a hundred audio recordings were found wrongly labeled by the discography given in MazurkaBL during the research progress. By a cover song detection algorithm and manual verification, we created a clean version of the discography, provided here.

Transcribed Midis

We applied the piano transcription algorithm by Kong et al. to the above two datasets (cleaned version). The transicribed midis are available here.

Citation

@ARTICLE{2023arXiv231000699T,
       author = {{Tang}, Jingjing and {Wiggins}, Geraint and {Fazekas}, Gyorgy},
        title = "{Pianist Identification Using Convolutional Neural Networks}",
      journal = {arXiv e-prints},
     keywords = {Computer Science - Sound, Electrical Engineering and Systems Science - Audio and Speech Processing},
         year = 2023,
        month = oct,
          eid = {arXiv:2310.00699},
        pages = {arXiv:2310.00699},
          doi = {10.48550/arXiv.2310.00699},
archivePrefix = {arXiv},
       eprint = {2310.00699},
 primaryClass = {cs.SD},
       adsurl = {https://ui.adsabs.harvard.edu/abs/2023arXiv231000699T},
      adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}

Contact

Jingjing Tang: jingjing.tang@qmul.ac.uk

About

A pianist identification system based on midi inputs, using convolutional neural networks. (IS2 2023)

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages