Skip to main content

Python bindings for Apple CoreAudio

Project description

CoreMusic: Python bindings for Apple CoreAudio

PyPI version License

A zero-dependency music development toolkit for macOS providing Python access to Apple's CoreAudio and CoreMIDI frameworks via Cython. Offers both functional (C-style) and object-oriented (Pythonic) APIs with automatic resource management.

Features

Framework Capabilities
CoreAudio Hardware abstraction, device management, format handling
AudioToolbox AudioFile I/O, AudioQueue streaming, AudioComponent discovery
AudioUnit Plugin hosting, real-time processing, render callbacks, MIDI instrument control
CoreMIDI Device/endpoint management, UMP (MIDI 1.0/2.0), thru connections, transforms
Ableton Link Network tempo sync, beat-accurate playback/sequencing

Audio: File I/O (WAV, AIFF, MP3), real-time processing, analysis (peak, RMS, tempo, key), buffer pool, memory-mapped I/O

MIDI: Device discovery, virtual devices, routing, transformation pipeline (transpose, quantize, humanize, harmonize)

Music Theory: 25+ scales, 35+ chords, Note/Interval/Scale/Chord classes, time signatures, rhythmic patterns

Installation

pip install coremusic

Requirements: macOS, Python 3.11+

Optional Dependencies

CoreMusic has zero runtime dependencies by default. Optional features require additional packages:

# Audio analysis (beat detection, pitch detection, key detection)
pip install coremusic[analysis]

# Visualization (waveform plots, spectrograms)
pip install coremusic[visualization]

# All optional features
pip install coremusic[all]

Check feature availability at runtime:

from coremusic.objects import NUMPY_AVAILABLE
from coremusic.audio.analysis import AudioAnalyzer
import coremusic.utils.scipy as spu

if NUMPY_AVAILABLE:
    # NumPy-based features available
    data = audio.read_as_numpy()

if spu.SCIPY_AVAILABLE:
    # SciPy-based analysis available
    analyzer = AudioAnalyzer("song.wav")
    tempo = analyzer.detect_beats().tempo

Building from Source

git clone https://github.com/shakfu/coremusic.git
cd coremusic
make        # Build
make test   # Run tests

Command Line Interface

% coremusic --help
usage: coremusic [-h] [--version] [--json] <command> ...

CoreMusic - Python bindings for Apple CoreAudio.

positional arguments:
  <command>
    audio     Audio file operations
    device    Audio device management
    plugin    AudioUnit plugin discovery
    analyze   Audio analysis and feature extraction
    convert   Convert audio files between formats
    midi      MIDI operations
    sequence  MIDI sequence operations
    completion
              Generate shell completion scripts

options:
  -h, --help  show this help message and exit
  --version   show program's version number and exit
  --json      Output in JSON format
Command Description
audio Audio file operations (info, play, record, duration, metadata)
devices Audio device management (list, info, volume, mute, set-default)
plugin AudioUnit plugins (list, find, info, params, process, render)
analyze Audio analysis (levels, tempo, key, spectrum, loudness, onsets)
convert Audio conversion (file, batch, normalize, trim)
midi MIDI operations (list, info, play, quantize, receive, send, panic)
sequence MIDI sequence operations (info, play, tracks)
completion Generate shell completion scripts (bash, zsh, fish)

Shell Completion

Enable tab completion for commands and options:

# Bash (add to ~/.bashrc)
eval "$(coremusic completion bash)"

# Zsh (add to ~/.zshrc)
eval "$(coremusic completion zsh)"

# Fish (add to ~/.config/fish/config.fish)
coremusic completion fish | source

Examples

# Audio
coremusic audio play song.wav --loop
coremusic audio record -o recording.wav -d 10
coremusic analyze tempo song.wav
coremusic convert normalize input.wav output.wav --target -1.0

# Devices
coremusic device list
coremusic device volume "MacBook Pro Speakers" 0.5

# Plugins
coremusic plugin list --type effect
coremusic plugin list --name-only | grep -i reverb
coremusic plugin process "AUDelay" input.wav -o output.wav
coremusic plugin render "DLSMusicDevice" song.mid -o rendered.wav

# MIDI
coremusic midi list
coremusic midi receive                              # Display incoming MIDI
coremusic midi receive -o recording.mid             # Save to MIDI file
coremusic midi receive --plugin "DLSMusicDevice"    # Route to synth plugin
coremusic midi play song.mid
coremusic midi quantize input.mid -o quantized.mid --grid 1/16
coremusic midi panic

# JSON output for scripting
coremusic --json plugin list --type instrument

Quick Start

One-Liner Convenience Functions

from coremusic.shortcuts import play, play_async, convert
from coremusic.shortcuts import analyze_tempo, analyze_key, get_info
from coremusic.shortcuts import list_devices, list_plugins

# Quick playback
play("song.wav")                       # Blocking playback
handle = play_async("song.wav")        # Non-blocking, returns control handle
handle.stop()                          # Stop when done

# Quick analysis
tempo = analyze_tempo("song.wav")      # Get BPM
key, mode = analyze_key("song.wav")    # Get musical key
info = get_info("song.wav")            # Get file metadata

# Quick conversion
convert("input.wav", "output.mp3")

# List resources
devices = list_devices()
plugins = list_plugins(type='effect')

Audio Files

from coremusic.objects import AudioFile

with AudioFile("audio.wav") as f:
    print(f"Duration: {f.duration:.2f}s, Rate: {f.format.sample_rate}Hz")
    data, count = f.read_packets(0, 1000)

Audio Playback

from coremusic.objects import AudioPlayer

player = AudioPlayer()
player.load_file("audio.wav")
player.setup_output()
player.play()
player.set_looping(True)
# ... later
player.stop()

AudioUnit Plugins

from coremusic.audio.audiounit_host import AudioUnitHost

# Discover and use plugins
host = AudioUnitHost()
effects = host.discover_plugins(type='effect')

with host.load_plugin("DLSMusicDevice", type='instrument') as synth:
    synth.note_on(channel=0, note=60, velocity=100)
    time.sleep(1.0)
    synth.note_off(channel=0, note=60)

MIDI

from coremusic.objects import MIDIClient

client = MIDIClient("My App")
output_port = client.create_output_port("Output")
output_port.send_data(destination, b'\x90\x3C\x7F')  # Note On
client.dispose()

MIDI Transformation

from coremusic.midi.utilities import MIDISequence
from coremusic.midi.transform import Pipeline, Transpose, Quantize, Humanize

seq = MIDISequence.load("input.mid")
pipeline = Pipeline([
    Transpose(semitones=5),
    Quantize(grid=0.125, strength=0.8),
    Humanize(timing=0.02, velocity=10),
])
pipeline.apply(seq).save("output.mid")

Music Theory

from coremusic.music.theory import Note, Scale, ScaleType, Chord, ChordType

c4 = Note.from_midi(60)  # Middle C
c_major = Scale(c4, ScaleType.MAJOR)
cmaj7 = Chord(c4, ChordType.MAJOR_7)

Rhythm and Meter

from coremusic.music.theory import TimeSignature, NoteValue, Duration, RhythmPattern

ts = TimeSignature(4, 4)
dotted_quarter = Duration(NoteValue.QUARTER, dots=1)
triplet = Duration.triplet(NoteValue.EIGHTH)

pattern = RhythmPattern.straight_eighths(8)
onset_times = pattern.scale_to_tempo(120)  # At 120 BPM

Ableton Link

from coremusic import link

with link.LinkSession(bpm=120.0) as session:
    state = session.capture_app_session_state()
    current_time = session.clock.micros()
    beat = state.beat_at_time(current_time, quantum=4.0)
    print(f"Beat: {beat:.2f}, Tempo: {state.tempo:.1f} BPM")

API Overview

Object-Oriented API (Recommended)

Pythonic wrappers with automatic resource management:

  • Context managers (with statements) for automatic cleanup
  • Type-safe classes instead of integer IDs
  • Properties, iteration, operators
  • IDE autocompletion and type hints
from coremusic.objects import AudioFile, AudioFormat, MIDIClient
from coremusic.constants import AudioFileProperty, AudioFormatID

Functional API (Advanced)

Direct access to CoreAudio C functions for maximum control:

  • Direct mapping to CoreAudio C APIs
  • Fine-grained resource management
  • Familiar for CoreAudio developers
import coremusic.capi as capi

audio_file = capi.audio_file_open_url("audio.wav")
format_data = capi.audio_file_get_property(audio_file, capi.get_audio_file_property_data_format())
capi.audio_file_close(audio_file)

Both APIs interoperate - OO objects expose underlying IDs when needed.

Architecture

src/coremusic/
  __init__.py          # Package entry, OO API exports
  capi.pyx/pxd         # Cython bindings to CoreAudio/CoreMIDI
  objects/             # Object-oriented wrappers
    audio.py           # AudioFile, AudioFormat, AudioQueue, etc.
    audiounit.py       # AudioUnit, AudioComponent
    midi.py            # MIDIClient, MIDIPort
    devices.py         # AudioDevice, AudioDeviceManager
    music.py           # MusicPlayer, MusicSequence, MusicTrack
    exceptions.py      # Exception hierarchy
  audio/               # Analysis, buffer pool, streaming
  midi/                # Utilities, transforms, Link integration
  music/               # Theory (scales, chords)
  cli/                 # Command-line interface
  link.pyx             # Ableton Link bindings

Linked frameworks: CoreAudio, AudioToolbox, AudioUnit, CoreMIDI, CoreFoundation

Testing

make test           # Fast tests
make test-all       # All tests (1600+)

Documentation

Getting Started

Tutorials

Step-by-step guides for common tasks:

Reference

Executable Examples

The tests/tutorials/ directory contains doctest-based tutorials that serve as both documentation and tests:

# Run all tutorial doctests
pytest tests/tutorials/ --doctest-modules -v

# Run specific tutorial
pytest tests/tutorials/test_audio_file_basics.py --doctest-modules -v

Available tutorials: test_quickstart.py, test_audio_file_basics.py, test_midi_basics.py, test_effects_processing.py, test_music_theory.py

Resources

License

MIT License - see LICENSE file.

Download files

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

Source Distribution

coremusic-0.2.1.tar.gz (4.9 MB view details)

Uploaded Source

Built Distributions

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

coremusic-0.2.1-cp314-cp314-macosx_15_0_arm64.whl (634.1 kB view details)

Uploaded CPython 3.14macOS 15.0+ ARM64

coremusic-0.2.1-cp313-cp313-macosx_15_0_arm64.whl (632.3 kB view details)

Uploaded CPython 3.13macOS 15.0+ ARM64

coremusic-0.2.1-cp312-cp312-macosx_15_0_arm64.whl (633.2 kB view details)

Uploaded CPython 3.12macOS 15.0+ ARM64

coremusic-0.2.1-cp311-cp311-macosx_15_0_arm64.whl (629.8 kB view details)

Uploaded CPython 3.11macOS 15.0+ ARM64

coremusic-0.2.1-cp310-cp310-macosx_15_0_arm64.whl (629.2 kB view details)

Uploaded CPython 3.10macOS 15.0+ ARM64

File details

Details for the file coremusic-0.2.1.tar.gz.

File metadata

  • Download URL: coremusic-0.2.1.tar.gz
  • Upload date:
  • Size: 4.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.12

File hashes

Hashes for coremusic-0.2.1.tar.gz
Algorithm Hash digest
SHA256 5590a9a2a0913de8081d740d9b23ecde9d858054db9bb0a26c7bcaaf77455b73
MD5 97f9049443544339a9a6cefa97e59d38
BLAKE2b-256 56c2e8c7114c15b7c656552bdabf97c2b5bc7680db993356496b00616f01ae98

See more details on using hashes here.

File details

Details for the file coremusic-0.2.1-cp314-cp314-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for coremusic-0.2.1-cp314-cp314-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 e17b1533805ef94bc821e5b27dfc93dbb353676eb4d135a396a32245e009298c
MD5 dea6267dd982f081ffb258d96adb49a2
BLAKE2b-256 81dea25244146689ce93d53552ace9a3eab9168c38cdd1be845e46035b73d67f

See more details on using hashes here.

File details

Details for the file coremusic-0.2.1-cp313-cp313-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for coremusic-0.2.1-cp313-cp313-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 8a7e390422db64eda1deffa68909e69c5677b9f8f9a5e5d4dce77cd52cf763c6
MD5 94be981960ab0cde0283bbbeab81f6cc
BLAKE2b-256 73891e261e12f11bb3a435f32a56410ab3ca6bd74c003824e1850551f9cf595b

See more details on using hashes here.

File details

Details for the file coremusic-0.2.1-cp312-cp312-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for coremusic-0.2.1-cp312-cp312-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 60b48baa9468d30c61400fb81888b1ca19c16984b5a2328bd5ff2465c74e7a21
MD5 8a8e742af25049cff56340fd3bcb10c5
BLAKE2b-256 1dee333171f25000544550e474f2f8aeef6b282ea06846d61cec9c98d8e73b4d

See more details on using hashes here.

File details

Details for the file coremusic-0.2.1-cp311-cp311-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for coremusic-0.2.1-cp311-cp311-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 60ac2355fd68f5ab6e622444e238a13cfe605f30f80fcc449545e7a2489575a5
MD5 62992840556d15f0ce50e2585cb26e4d
BLAKE2b-256 c6fdc20afb1bcc6f7316af812ab288a428d48248956fd7dade65f5a18dba3b3b

See more details on using hashes here.

File details

Details for the file coremusic-0.2.1-cp310-cp310-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for coremusic-0.2.1-cp310-cp310-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 93c874c147873c572db4f54c344e3d99b6ca5976767090b442468894c322348c
MD5 e6032aa34da571eaf4dc7716342e0e7d
BLAKE2b-256 d994c17292d6ede1e068b17fa8962d40e6cf03475983781156654ed815b4a97a

See more details on using hashes here.

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