Source Code | Tickets | Trello | Twitter | Patreon | © Michael DeHaan, 2020



The Python API to Warp provides a backend to everything MIDI note and composition related. It can enable a wide variety of algorithmic composition and generative music, embedded projects, and sonic installations, but is also the same code that powers the Warp UI backend.

What's here? Lots. The API provides a grid system of scenes and tracks, device and instrument management, included and user supplied scale types, a pattern system, a custom MIDI effects system ("transforms"), and a framework for introducing highly controllable randomness and direction management. Warp handles all note timing considerations, MIDI math, and basic music theory math for you.

Sorry, that's a mouthful. What we mean to say is this: This could be the most powerful MIDI sequencing library on Earth.

As there is a lot here, we don't want you to get overwhelmed - we suggest also reading the extensive API Examples, loading the examples - playing them - and tweaking them, will help you learn the API a lot faster than using the reference guide alone.

Running Demos 

To run the API demos, first install warp and then from your console:

cd warp_checkout_location
cd examples/api/

MIDI Interface Considerations 

The API demos are written to use a specific MIDI interface. If you do not have an interface named the same as the examples, you can set an environment variable to make the demos easy to run, rather than changing the script. On a MAC, this is done as follows:

WARP_MIDI_DEVICE="My Device Name" PYTHONPATH=. python3
Or alternatively:
export WARP_MIDI_DEVICE="My Device Name"

Most of the included examples use one or two MIDI tracks, some use more. Search for "tracks" in the code and see what is set up, and try to configure some instruments (in your DAW or hardware) that sound like a good match. If you need to tweak the track numbers in the instrument definitions in those files, that's also fine. The drum example should use a kick and a snare drum, but the other demos will sound fine with any polyphonic synth with a short enough decay and release time. A piano instrument would also be fine.

Object Model 

Here's a diagram of the object relationships in Warp. Don't get too overwhelmed as when you look at the examples it will start to fit together better:

API Design Philosophy 

You will notice that the API examples do not use a lot of variables, object assignments, or loops. This is because we want to mostly make the API accessible to folks who are not full time programmers.

In many cases our examples will pass around the name of an object, rather than an object itself. There also are no loops. Rather than have a looping system, Warp is the looping system. Warp contains self contained randomness features as well, allowing access to compositional variety without extensive programming. Thus, simple things can be constructed more simply, all by also paving the way to support for a UI and everything it needs.

In some cases, some objects - like Evaluators are also a bit of lazy-evaluating black magic. If they were evaluated instantly, as in pure python, they would not be as useful as if they were implemented in a way that can take advantage of the event loop.

Next Steps 

  Tip: open the API examples in a new tab while reading the API guide.
  If you get stuck or have a question, we're always wanting to refine our documentation, so please Email Michael. We'd be glad to hear from you!
Ready to learn the API? Start with Song.