Skip to main content

Make piano-roll animations from midi files

Project description

Midani

Demo frame

Make piano-roll animations from midi files.

Another demo frame

Dependencies

Requires Python >= 3.8

  • Python libraries:
    • opencv-python
    • mido
    • matplotlib (optionally, see below)
  • Other:
    • R (optionally, see below)
    • FFmpeg to add audio

Installation

The easiest way to install is from PyPI:

pip install midani

You can also install by downloading the repository and then running the following commands from the repository directory.

pip install -r requirements.txt
pip install .

Either way, you will need to install

  • either R or matplotlib to do the plotting of frames. R turns out to be quite a faster than matplotlib, so it is recommended.
  • FFmpeg, used to add audio to the video.

On MacOS, R and FFmpeg can be installed using homebrew:

brew install r
brew install ffmpeg

Matplotlib can be installed with pip:

pip install matplotlib

Example Usage:

Create an animation with the default settings:

midani --midi [MIDIFILE]

The same, but add audio as well:

midani --midi [MIDIFILE] --audio [AUDIOFILE]

The same, but animate at 2fps rather than the default 30fps, so you can get a flavor of the results without waiting quite so long:

midani --midi [MIDIFILE] --audio [AUDIOFILE] --test

Create an animation using one of the sample settings and one of the sample midi/audio files:

midani --settings sample_settings/settings1.py

Usage

usage: midani [-h] [-m MIDI] [-a AUDIO] [-s [SETTINGS ...]] [-t] [-e]
              [-f FRAMES]

Animate a midi file. The path to a midi file must either be included as a
command line argument with -m/--midi, or it must be specified with the
"midi_fname" keyword argument in a settings file provided with -s/--settings.

optional arguments:
  -h, --help            show this help message and exit
  -m MIDI, --midi MIDI  path to midi file to animate
  -a AUDIO, --audio AUDIO
                        path to audio file to add to video
  -s [SETTINGS ...], --settings [SETTINGS ...]
                        path to settings files, each containing a Python
                        dictionary
  -t, --test            set frame rate to a maximum of 2 fps
  -e, --eval            use 'eval()' rather than 'ast.literal_eval()' to parse
                        settings.
  -f FRAMES, --frames FRAMES
                        a comma-separated list of numbers (with no spaces);
                        specifies a list of individual frames to be drawn

Configuration

For full documentation of the various settings available, and for how to set per-voice settings, see docs/settings.md.

To configure with custom settings, save one or more files, each containing only a python dictionary, and pass them as arguments with -s/--settings. (Usually, only one settings file is necessary, but you might want to use more than one if, for instance, you want to define a general style shared between several animations, but nevertheless tweak the settings for each individual midi file. When the same setting is found in multiple settings files, the setting in the last-listed file has precedence.)

For example, if you wanted a "primary color" note color palette, with white background color, you could save the following dictionary in a file called example.py and then invoke the script with --settings example.py:

{
    "color_palette": (
        (255, 0, 0),
        (0, 255, 0),
        (0, 0, 255),
    ),
    "bg_colors": (
        (255, 255, 255),
    ),
}

For more examples, see the files in sample_settings/.

The settings files are ordinarily parsed with ast.literal_eval(), thus (to quote the Python docs) they "may only consist of the following Python literal structures: strings, bytes, numbers, tuples, lists, dicts, sets, booleans, and None." (If you get an error like ValueError: malformed node or string, then you are probably using expressions that ast.literal_eval() cannot parse.) If you wish to use conveniences like arithmetic expressions or list comprehensions, you can pass the --eval flag, and the settings files will instead be parsed with eval(). Don't use this flag with settings that you do not trust.

Sample files

The subdirectory sample_settings contains a few sample settings files to quickly demonstrate a few of the different options available.

The subdirectory sample_music contains a few midi files to play with for demo purposes. I created these algorithmically with another project of mine. I have provided mp3s generated therefrom with fluidsynth and a free General MIDI soundfont. The audio fidelity may leave something to be desired.

Known issues

VLC is recommended for playback of output video files. Videos also play back correctly on Youtube. But they don't always play back correctly with Quicktime:

  • if framerate is too slow (e.g., with --test flag), there is no video playback (only a static green screen)
  • audio playback doesn't seem to work.

Major TODOs

  • finish sample_settings

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

midani-0.0.3.tar.gz (56.4 kB view details)

Uploaded Source

Built Distribution

midani-0.0.3-py3-none-any.whl (59.7 kB view details)

Uploaded Python 3

File details

Details for the file midani-0.0.3.tar.gz.

File metadata

  • Download URL: midani-0.0.3.tar.gz
  • Upload date:
  • Size: 56.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.4

File hashes

Hashes for midani-0.0.3.tar.gz
Algorithm Hash digest
SHA256 1c9689e99414051498c3ef240fb36d65b09e6a98d07f2a9579d26696927d531c
MD5 9adb7af9d15c7a09de85a89f9ae2a347
BLAKE2b-256 381d4b4b1a8e3239e2ccebd4edcf871e223610e2afc11d49aafec12c849e36a4

See more details on using hashes here.

File details

Details for the file midani-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: midani-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 59.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.4

File hashes

Hashes for midani-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 aa542fcdb8e46bcf9d5c2021bdd5112d7c8233c77091711d5112bb108ffbc5df
MD5 7cc770ebc84a971a62455125b4d44e35
BLAKE2b-256 252e980e29aabe87d014e5c33d538144d0a7f6507a3997aaafea783b851f183d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page