Skip to main content

Compose music with streams.

Project description


Compose music with streams


Aleatora is a music composition framework, implemented as a Python library, built around the abstraction of lazy, effectful, replayable streams.

What does that mean? Like most audio synthesis frameworks, Aleatora lets you build up complex sounds by connecting generators in an audio graph (function composition + parallel composition). Unlike most, it also lets you build things up horizontally: streams can be composed sequentially, so the audio graph change over time on its own (based on the computation described in the graph itself).

Additionally, streams may contain any kind of data type, not just samples. So you can use the same basic abstraction, and all the operations that it offers, to work with strings, events, arrays, MIDI data, etc., just as well as with individual audio samples.


virtualenv venv -p pypy3  # or python3, if you're okay with more underruns
source venv/bin/activate
pip install aleatora  # for optional features, append a bracketed list like `[speech,foxdot]` (or `[all]`)

To ensure installation succeeded and that you can get sound out, try playing a sine tone:

import aleatora as alt


Aleatora is early-stage software. There is no documentation as yet, beyond this README and code comments, but this will soon change!

Download files

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

Files for aleatora, version 0.1.0
Filename, size File type Python version Upload date Hashes
Filename, size aleatora-0.1.0-py3-none-any.whl (47.1 kB) File type Wheel Python version py3 Upload date Hashes View
Filename, size aleatora-0.1.0.tar.gz (44.8 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page