GithubHelp home page GithubHelp logo

thingthatis / musiclang_predict Goto Github PK

View Code? Open in Web Editor NEW

This project forked from musiclang/musiclang_predict

0.0 0.0 0.0 259 KB

AI Prediction api of the MusicLang package

License: GNU General Public License v3.0

Python 69.49% C 29.60% Makefile 0.91%

musiclang_predict's Introduction

MusicLang logo

MusicLang Predict, your controllable music copilot.


☞ You want to generate music that you can export to your favourite DAW in MIDI ?

☞ You want to control the chord progression of the generated music ?

☞ You need to run it fast on your laptop without a gpu ?


MusicLang is the contraction of β€œMusic” & β€œlanguage”: we bring advanced controllability features over music generation by manipulating symbolic music.


Table of contents

Quickstart πŸš€

Try it quickly πŸ“™


Open In Colab Open in Spaces

Go to our β™ΎColab, or to our πŸ€—HuggingFace space, we have a lot of cool examples, from generating creative musical ideas to continuing a song with a specified chord progression.

Install MusicLang β™«


Install the musiclang-predict package :

pip install musiclang_predict

Examples 🎹

1. Generate your first music πŸ•Ί


Open your favourite notebook and start generating music in a few lines :

from musiclang_predict import MusicLangPredictor
nb_tokens = 1024 
temperature = 0.9  # Don't go over 1.0, at your own risks !
top_p = 1.0 # <=1.0, Usually 1 best to get not too much repetitive music
seed = 16  # change here to change result, or set to 0 to unset seed

ml = MusicLangPredictor('musiclang/musiclang-v2') # Only available model for now

score = ml.predict(
    nb_tokens=nb_tokens,  # 1024 tokens ~ 25s of music (depending of the number of instruments generated)
    temperature=temperature,
    topp=top_p,
    rng_seed=seed # change here to change result, or set to 0 to unset seed
)
score.to_midi('test.mid') # Open that file in your favourite DAW, score editor or even in VLC

2. Controlling chord progression generation πŸͺ©


You had a specific harmony in mind, right ? MusicLang allows fine control over the chord progression of the generated music. Just specify it as a string like below, choose a time signature and let the magic happen.

from musiclang_predict import MusicLangPredictor

# Control the chord progression
# Chord qualities available : M, m, 7, m7b5, sus2, sus4, m7, M7, dim, dim0.
# You can also specify the bass if it belongs to the chord (eg : Bm/D)
chord_progression = "Am CM Dm E7 Am" # 1 chord = 1 bar
time_signature = (4, 4) # 4/4 time signature, don't be too crazy here 
nb_tokens = 1024 
temperature = 0.8
top_p = 1.0
seed = 42

ml = MusicLangPredictor('musiclang/musiclang-v2')

score = ml.predict_chords(
    chord_progression,
    time_signature=time_signature,
    temperature=temperature,
    topp=top_p,
    rng_seed=seed # set to 0 to unset seed
)
score.to_midi('test.mid', tempo=120, time_signature=(4, 4))

Disclaimer : The chord progression is not guaranteed to be exactly the same as the one you specified. It's a generative model after all. This may occur more frequently when using an exotic chord progression or setting a high temperature.

3. Generation from an existing music πŸ’ƒ


What if I want to use MusicLang from an existing music ? Don't worry, we got you covered. You can use your music as a template to generate new music. Let's continue with some Bach music and explore a chord progression he might have used:

from musiclang_predict import MusicLangPredictor
from musiclang_predict import corpus

song_name = 'bach_847' # corpus.list_corpus() to get the list of available songs
chord_progression = "Cm C7/E Fm F#dim G7 Cm"
nb_tokens = 1024 
temperature = 0.8 
top_p = 1.0 
seed = 3666 

ml = MusicLangPredictor('musiclang/musiclang-v2')

score = ml.predict_chords(
    chord_progression,
    score=corpus.get_midi_path_from_corpus(song_name),
    time_signature=(4, 4),
    nb_tokens=1024,
    prompt_chord_range=(0,4),
    temperature=temperature,
    topp=top_p,
    rng_seed=seed # set to 0 to unset seed
)

score.to_midi('test.mid', tempo=110, time_signature=(4, 4))

What's coming next at MusicLang? πŸ‘€


We are working on a lot of cool features, some are already encoded in the model :

  • A control over the instruments used in each bar and their properties (note density, pitch range, average velocity);
  • Some performances improvements over the inference C script;
  • A faster distilled model for real-time generation that can be embedded in plugins or mobile applications;
  • An integration into a DAW as a plugin;
  • Some specialized smaller models depending on our user's needs;
  • And more to come! 😎

How does MusicLang work? πŸ”¬


If you want to learn more about how we are moving toward symbolic music generation, go to our technical blog. The tokenization, the model are described in great details:


We are using a LLAMA2 architecture (many thanks to Andrej Karpathy's awesome llama2.c), trained on a large dataset of midi files (The CC0 licensed LAKH). We heavily rely on preprocessing the midi files to get an enriched tokenization that describe chords & scale for each bar. The is also helpful for normalizing melodies relative to the current chord/scale.

Contributing & spread the word 🀝


We are looking for contributors to help us improve the model, the tokenization, the performances and the documentation. If you are interested in this project, open an issue, a pull request, or even contact us directly.

Whether you're contributing code or just saying hello, we'd love to hear about the work you are creating with MusicLang. Here's how you can reach out to us:

License βš–οΈ


MusicLang Predict (This package) is licensed under the GPL-3.0 License. However please note that specific licenses applies to our models. If you would like to use the model in your commercial product, please contact us. We are looking forward to hearing from you !

The MusicLang base language package on which the model rely (musiclang package) is licensed under the BSD 3-Clause License.

musiclang_predict's People

Contributors

floriangardin avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.