Skip to main content

A live-coding performance tool that turns Python code structure into music via SuperCollider.

Project description

PyCodeDJ

日本語版 README はこちら · Full Manual (EN) · マニュアル (JA)

A live-coding environment that translates Python code structure into music in real time. Every save changes the performance.


Concept

PyCodeDJ connects "writing code" directly to "making sound."

Add more for loops and the modulation speeds up. Deepen nesting and the filter opens up. Fill in comments and the space grows. Write dj.pattern = "x . x ." and that rhythm plays. Write dj.pattern = "0 . 3 . 5 ." and those pitches ring out.

Two things set it apart from existing Python ↔ SuperCollider bridges (sc3nb, supriya):

  • Hot-reload performance — swap out a loop without stopping it. Saving a file is an immediate sound change.
  • Two performance styles — auto-generation from code structure, and explicit dj.pattern notation for rhythm and pitch. Mix them freely in the same file.

Architecture

[Python engine]  →OSC→  [SuperCollider]  →audio out→  speakers
      ↓ OSC
  [Hydra etc.]  →video out→  screen
Layer Role Technology
Control Code analysis, scheduling, OSC dispatch Python 3.10+, python-osc, watchdog
Audio Real-time sound synthesis SuperCollider (scsynth)
Visual Music-synced visuals Hydra or Pyxel

BPM clock is held by SuperCollider's TempoClock. Python only sends parameter updates over OSC; timing accuracy is delegated to SuperCollider.


Code Structure → Music Parameter Mapping

Code feature Music parameter
Max nesting depth Filter Cutoff (200–4000 Hz)
Control-flow count (if/for/while) LFO rate (0.1–5.0 Hz)
Function definition count Polyphony voice count (1–4)
Comment ratio Reverb depth (0.0–0.8)
dj.volume Amplitude (0.0–1.0)
dj.cutoff / dj.reverb Direct filter/reverb override
dj.eq / dj.low / dj.mid / dj.high Simple 3-band EQ

Installation

Requirements

  • Python 3.10 or later
  • SuperCollider (with scsynth available)
pip install 'pycodedj[watch]'

The [watch] extra enables the pycodedj watch command.

Development install:

git clone https://github.com/kanekoyuichi/pycodedj
cd pycodedj
pip install -e ".[dev]"

Quick Start

1. Boot SuperCollider and load the synths

Open sc/synths.scd in the SuperCollider IDE. Press Ctrl+A (Cmd+A on Mac) to select all, then Ctrl+Enter (Cmd+Enter on Mac) to run. When the Post window shows this, you're ready:

PyCodeDJ synths loaded. Ready. OSC port: 57120

2. Write a live-coding file

from pycodedj import dj, loop

# Code-structure mode: the shape of your code maps to sound
@loop(interval=2.0)
def bass():
    dj.volume = 0.4
    for i in range(8):
        if i % 2 == 0:
            pass

# Pattern mode: specify rhythm and pitch explicitly
@loop(synth="kick_floor", beat=0.25)
def kick():
    dj.volume = 0.8
    dj.pattern = "x . x ."

@loop(synth="lead_acid", root="A3", scale="minor", beat=0.25)
def melody():
    dj.volume = 0.3
    dj.pattern = "0 . 3 . 5 ."

# Comments create space (reverb)
@loop(interval=4.0)
def pad():
    dj.volume = 0.1
    # ambient space
    # silence is music
    pass

3. Start watch mode

pycodedj watch demo.py

From here, just write code and save. Every save re-evaluates all loops.

4. Emergency stop

pycodedj panic

5. Stop one loop

pycodedj stop bass

6. Mute / unmute

pycodedj mute bass
pycodedj unmute bass

7. Set BPM and list synths

pycodedj bpm 128
pycodedj list-synths

Using dj.pattern

dj.pattern lets you specify rhythm and pitch explicitly.

from pycodedj import dj, loop

# Trigger pattern (x = hit, . = rest)
@loop(synth="kick_floor", beat=0.25)
def kick():
    dj.volume = 0.8
    dj.pattern = "x . x ."

# Pitch pattern (integer = scale degree)
@loop(synth="bass_acid", root="A1", scale="minor", beat=0.25)
def bass():
    dj.volume = 0.35
    dj.pattern = "0 . 3 . 5 ."

# Chords and ties
@loop(synth="note", root="A1", scale="minor", beat=0.25)
def chord():
    dj.volume = 0.25
    dj.pattern = "0 . [0 3] ~ 5 . 3 ."
    # [0 3] = two-note chord, ~ = sustain the previous note one more step

Token reference:

Token Meaning
x Trigger (plays root note)
. Rest (silence)
0, 1, 2 Scale degree (pitch)
[0 3] Chord (multiple degrees simultaneously)
~ Tie (extends the previous note/chord by one step)

@loop arguments for pattern mode:

Argument Description
synth= Synth name to use
root= Root note (e.g. "A3", "C4")
scale= Scale name (e.g. "minor", "major", "pentatonicMinor")
beat= Step length in seconds. 0.25 = sixteenth note at 60 BPM

Example Files

File Contents
examples/demo.py Intro demo: bass / melody / pad
examples/club_set.py Sub-heavy club set: 11 loops with kick, rumble, sub, acid, hats, and room noise
examples/sound_showcase.py All 60 synths — evaluate one at a time to audition

OSC Address Reference

Address Type Parameter
/pycodedj/loop/<name>/params int, float, float, float, float voice_count, cutoff, lfo_rate, reverb, amp
/pycodedj/loop/<name>/pattern int, str, float, str, int… Pattern data
/pycodedj/loop/<name>/pattern_stop Stop pattern
/pycodedj/loop/<name>/amp float Amplitude (compatibility)
/pycodedj/bpm float SuperCollider TempoClock BPM

Requirements

  • Recommended OS: macOS (low-latency Core Audio) or Linux (Raspberry Pi 5, etc.)
  • Python: 3.10 or later
  • SuperCollider: 3.12 or later

Roadmap

  • Python → SuperCollider OSC prototype
  • Hot-reload live loop implementation (pycodedj watch)
  • Sprint 1: Live stability (panic, SyntaxError recovery, mute/solo, status)
  • Sprint 2: Music DSL (dj.pattern, @loop parameter expansion: synth, root, scale, beat)
  • Sprint 3: Sound design and playability (SynthDef cleanup, bpm, list-synths)
  • Sprint 4: Hydra visualiser integration

License

MIT + Commons Clause — free to use, modify, and perform (including paid live performances). Selling or commercially distributing the software itself is not permitted. See LICENSE for details.


Support

This project is maintained on a best-effort basis.

Bug reports and suggestions may be submitted through GitHub Issues, but responses and fixes are not guaranteed.

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

pycodedj-0.8.0.tar.gz (673.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pycodedj-0.8.0-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file pycodedj-0.8.0.tar.gz.

File metadata

  • Download URL: pycodedj-0.8.0.tar.gz
  • Upload date:
  • Size: 673.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pycodedj-0.8.0.tar.gz
Algorithm Hash digest
SHA256 c092492855170adf219e285762bf534d178eeec475354ab4664b787e19e266b2
MD5 030161c755031a9b5ed5b8bdb04da273
BLAKE2b-256 d40b1e80281e99f504cfa11bf7535b1fd4e5493c06978354cf5b685328ad832d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pycodedj-0.8.0.tar.gz:

Publisher: workflow.yml on kanekoyuichi/pycodedj

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pycodedj-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: pycodedj-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 21.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pycodedj-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7f178f12ec1b68faa89a7913078e6e3cdc7455d9d26cd074d1f42d3521d350f4
MD5 15f1114ddaca227608c9df7985690b79
BLAKE2b-256 e0143ed053b89cfbe51ddbc3128076a144c7d306b00cd375f8cd7116d3043eb8

See more details on using hashes here.

Provenance

The following attestation bundles were made for pycodedj-0.8.0-py3-none-any.whl:

Publisher: workflow.yml on kanekoyuichi/pycodedj

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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