Monster Piano Transformer
Ultra-fast and very well fitted solo Piano music transformer
In the heart of a grand piano black and blue,
A fuzzy monster with eyes of yellow hue,
Its fingers dance upon the ivory keys,
Weaving melodies that soothe and please.
Musical notes float like leaves on breeze,
Harmony fills the air with gentle ease,
Each key stroke a word in a song unsung,
A symphony of joy that sets the heart alight, free and light.
The monster plays with such delight,
Lost in the rhythm, lost in the light,
Its fur a blur as it moves with grace,
A pianist born from a whimsical place.
Monster Piano, a title it bears,
A fusion of art and melodic airs,
Where creativity and music blend,
In this magical concert that never ends.
Let the monster's music fill the air,
And wash away our every care,
For in its song, we find repose,
And in its rhythm, our spirits glow.
Install
pip install monsterpianotransformer
(Optional) FluidSynth for MIDI to Audio functinality
Ubuntu or Debian
sudo apt-get install fluidsynth
choco install fluidsynth
Quick-start use example
import monsterpianotransformer as mpt
model = mpt.load_model()
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path, model_with_velocity=False)
output_tokens = mpt.generate(model, input_tokens, 600, return_prime=True)
mpt.tokens_to_midi(output_tokens[0], model_with_velocity=False)
Main features use examples
Long auto-continuation generation
import monsterpianotransformer as mpt
model = mpt.load_model()
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path, model_with_velocity=False)
output_tokens = mpt.generate_long(model, input_tokens, return_prime=True)
mpt.tokens_to_midi(output_tokens[0], model_with_velocity=False)
Pitches inpainting
import monsterpianotransformer as mpt
model = mpt.load_model()
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path, model_with_velocity=False)
output_tokens = mpt.inpaint_pitches(model, input_tokens)
mpt.tokens_to_midi(output_tokens, model_with_velocity=False)
Simple velocities inpainting
import monsterpianotransformer as mpt
model = mpt.load_model(model_name='with velocity - 3 epochs')
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path, model_with_velocity=True)
output_tokens = mpt.inpaint_velocities_simple(model, input_tokens)
mpt.tokens_to_midi(output_tokens, model_with_velocity=True)
Seq2Seq velocities inpainting
import monsterpianotransformer as mpt
model = mpt.load_model(model_name='velocity inpainting - 3 epochs')
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path, model_with_velocity=True)
output_tokens = mpt.inpaint_velocities_seq2seq(model, input_tokens, verbose=True)
mpt.tokens_to_midi(output_tokens, model_with_velocity=True)
Timings inpainting
import monsterpianotransformer as mpt
model = mpt.load_model('timings inpainting - 2 epochs')
sample_midi_path = mpt.get_sample_midi_files()[6][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path)
output_tokens = mpt.inpaint_timings(model, input_tokens)
mpt.tokens_to_midi(output_tokens)
Bridge inpainting
import monsterpianotransformer as mpt
model = mpt.load_model('bridge inpainting - 2 epochs')
sample_midi_path = mpt.get_sample_midi_files()[11][1]
input_tokens = mpt.midi_to_tokens(sample_midi_path)
output_tokens = mpt.inpaint_bridge(model, input_tokens)
mpt.tokens_to_midi(output_tokens)
Project Los Angeles
Tegridy Code 2025