Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/RetroCirce/Music-SketchNet
ISMIR 2020 Paper repo: Music SketchNet: Controllable Music Generation via Factorized Representations of Pitch and Rhythm
https://github.com/RetroCirce/Music-SketchNet
deep-learning ismir jupyter-notebook music music-generation music-information-retrieval python variational-autoencoder
Last synced: 3 months ago
JSON representation
ISMIR 2020 Paper repo: Music SketchNet: Controllable Music Generation via Factorized Representations of Pitch and Rhythm
- Host: GitHub
- URL: https://github.com/RetroCirce/Music-SketchNet
- Owner: RetroCirce
- License: cc0-1.0
- Created: 2020-07-24T12:40:33.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-10-03T23:46:00.000Z (over 1 year ago)
- Last Synced: 2024-08-01T02:35:07.652Z (6 months ago)
- Topics: deep-learning, ismir, jupyter-notebook, music, music-generation, music-information-retrieval, python, variational-autoencoder
- Language: Jupyter Notebook
- Homepage:
- Size: 4.01 MB
- Stars: 80
- Watchers: 3
- Forks: 11
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Music-SketchNet Paper Repository
Music SketchNet: Controllable Music Generation via Factorized Representations of Pitch and Rhythm, ISMIR 2020
* [Paper Link](https://arxiv.org/abs/2008.01291)
* Some samples in this [link](https://drive.google.com/drive/folders/1CI__Tts_YUyHCjnunqyIHVrA-IasCgUq?usp=sharing).
* We plan to provide a website for you to create you own sketch music (--in construction--).
* Feel free to ask any question to [[email protected]](mailto:[email protected]), if you meet trouble in these codes.
## Intro
Music SketchNet allows you to specify your own music ideas, namely pitch contour and rhythm, in the monophonic music generation scenario.
It contains:
* SketchVAE converts the music meldoy tokens into the disentanglemd latent vector (z_pitch, z_rhythm)
* SketchInpainter receives the music latent vectors to predict the missing measure vector separately in rhythm and pitch space
* SketchConnector incorpoates a transformer encoder structure and random unmasking scheme in receiving the sketch control and finalizing the generation.
## Score Demo
Music SketchNet allows you to control the pitch, control the rhythm, or control both information in a music inpainting/completion scenario.
![The Score Demo](figs/figure_7.png)## Code Guidance
We provide a complete jupyter notebook tutorial/pipline to guide you into each step of the Music SketchNet:
* Data Processing
* VAE Models Constrution, Training, and Inference
* SketchNet Construction, Training, Inference, and Comarison with Other Models
* Experiments, including Model Metric Evaluation, VAE Independent Evaluation, Significance Test (in preparation), and Sketch Quantitaive AnalysisTo run the code, you need to down the extra material data from this [link](https://drive.google.com/drive/folders/1xmg4ijhVJTse-V2BQ1hEBG2hQGYDQjTp?usp=sharing)
> data.zip: all processed data npy files, if you want to go through all process, you need to download it.> response.csv: the subjective listening test, if you want to go through all process, you need to download it.
> generation_result_npy.zip: the generation results from our training in 4-3, 4-4, 4-5, we highly recommend you to download it to let you get familiar with the naming and process of the experiement.
> IrishFolkSong.zip: if you only want to train and test three VAE structures (from 1-1 to 2-3), you only need to download this basic music midi data
> model_backup.zip: if you only want to skip most process and test the model, you can download the saved parameters for all models we trained.
#### Quick Start:
> click the file [1-irish-process.ipynb](/1-irish-process.ipynb) follow from *1-irish-process.ipynb* to *5-3-bootstrap-sig-test.ipynb*In each folder, we provide the model python script, or the data loader. And it should be easily recognized by the folder name.
Below is the introduction of all jupyter notebook files:
* 1-irish-process.ipynb: process the irish folk song midi data for the later use in VAE trainings.
* 2-1-EC2VAE.ipynb: train EC2-VAE.
* 2-2-MeasureVAE.ipynb: train MeasureVAE.
* 2-3-1-SketchVAE-data-process.ipynb: Split the data into the format for the SketchVAE training.
* 2-3-2-SketchVAE-train.ipynb: train SketchVAE.
* 3-1-MusicInpaintNet.ipynb: train Music InpaintNet
* 3-2-SketchVAE_InpaintRNN.ipynb: train SketchVAE + InpaintRNN
* 3-3-SketchVAE_SketchInpainter.ipynb: train SketchInapinter (stage I training)
* 3-4-SketchNet.ipynb: train SketchNet (stage II training)
* 4-1 is deprecated
* 4-2-reptition-nonrepetition-dataset.ipynb: create sub-test set Irish-Test-R / NR
* 4-3-MusicInpaintNet-eval.ipynb: infer/output the generation from Music InpaintNet
* 4-4-SketchVAE-InpaintRNN-eval.ipynb: infer/output the generation from SketchVAE+InpaintRNN
* 4-5-SketchNet-eval.ipynb: infer/output the generation from SketchNet
* 5-1-loss_and_accuracy.ipynb: experiement concerned with the loss and the accuracy.
* 5-2-vae_independent_test.ipynb: Three VAE structures independent test
* 5-3-bootstrap-sig-test.ipynb: The significance testAmong all scripts, 2-1, 2-2, 3-1 are forked most from the original EC^2-VAE and Music InpaintNet repos.
## Credit
Please cite this paper if you want to use this work or base this work for the further project:
> @inproceedings{music-sketchnet,
> author = {Ke Chen and Cheng-i Wang and Taylor Berg-Kirkpatrick and Shlomo Dubnov},
> title = {Music SketchNet: Controllable Music Generation via Factorized Representations of Pitch and Rhythm},
> booktitle = {Proceedings of the 21th International Society for Music Information Retrieval Conference, {ISMIR}},
> year = {2020}
> }