Giter VIP home page Giter VIP logo

klang's Introduction

Klang

Block based synthesis and music library for Python. Klang is German for sound.

Getting Started

Prerequisites

We use Python bindings for PortAudio and RtMidi. On Mac they can be installed via Homebrew.

Installing

Klang can be installed via PyPi / pip or directly via setup.py. Note that there are some audio C extensions. Python fallbacks exists.

python3 setup.py build_ext --inplace

For developing you can link your working copy with

python3 setup.py develop

Running the tests

Tests can be run via with

python3 setup.py test

Safety First

As always when programming with sound: Unplug your headphones or be very sure of what you are doing! Also with low headphone volume bugs in the code can result in very unpleasant loud noises which could probably impair your hearing. Be careful!

Klang Primer

Klang provides various audio related blocks. Every block can have multiple in-and outputs and by connecting them with each other we can define our network. Once we are finished with patching we can run our network with by calling run_klang(*blocks). This function only needs some blocks which belong to the network. It will then automatically discovers the other blocks of the network and deduce an appropriate block execution order.

In the following script we create a 440 Hz sine oscillator which output gets send to the sound card.

from klang.audio import Oscillator, Dac
from klang.klang import run_klang

# Init blocks
osc = Oscillator(frequency=440.)
dac = Dac(nChannels=1)

# Define network
osc.output.connect(dac.input)

# Run it
run_klang(dac)

Audio can be written to disk as a WAV file with the filepath argument.

run_klang(*blocks, filepath='some/filepath.wav')

Connections

There are two different types of connections in Klang:

Value

These connection can hold any kind of Python object which will be propagated through the network and updated during each cycle. Most commonly these are numpy arrays holding audio or modulation signals (Input and Output classes).

Message

Discrete messages. Each message input has its own internal message queue. Most commonly Note messages (MessageInput and MessageOutput classes).

There are also corresponding Relay connections (Relay and MessageRelay classes). These are used to build composite blocks (blocks which contain there own network of child blocks). Relays can be used to interface between the inside and outside of an composite block.

Defining The Network

The connect method can be used to connect inputs and outputs with each other. Note that it is always possible to connect one output to multiple inputs but not the other way round. As a shorthand there are two overloaded operators:

  • Pipe operator |: Connect multiple blocks in series.
  • Mix operator +: Mix multiple value outputs together.
# Pipe operator
a | b | c

# Is equivalanet to:
# >>> a.output.connect(b.input)
# ... b.output.connect(c.input)
# Mix operator
mixer = a + b + c

# Is equivalanet to:
# >>> mixer = Mixer(nInputs=0)
# ... mixer.add_new_channel()
# ... a.output.connect(mixer.inputs[-1])
# ... mixer.add_new_channel()
# ... b.output.connect(mixer.inputs[-1])
# ... mixer.add_new_channel()
# ... c.output.connect(mixer.inputs[-1])

Examples

See the examples directory with a couple example script which illustrate the core functionality of Klang. Currently there are:

Coding Style

PEP8 / Google flavored. With the one exception for variable and argument names (camelCase). Function and in methods are snake_case().

Author

Acknowledgments

Thanks for the support and inputs!

klang's People

Contributors

atheler avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Forkers

drewja

klang's Issues

Add License

This is a great project, thanks! Could you add a license, please, so users would know if they could combine it with their software?

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.