Hypermuse is a browser-based audio and VJ visualization project built with Three.js. It turns audio energy into animated 3D geometry around a sphere and can map uploaded video frames onto those geometries for live performance visuals.
- Analyzes incoming audio with the Web Audio API (
AnalyserNode). - Splits the frequency spectrum into bands and tracks per-band energy.
- Maps those bands to points distributed on a sphere.
- Creates reactive shapes, lines, and polygons when band thresholds are exceeded.
- Optionally textures geometry with video frames for VJ-style visuals.
- Exposes many live controls (thresholds, hue, camera/light, rotation, density) through a controller window.
The app is mostly multi-page HTML + inline script, with shared helpers in js/.
controller.html-> openssonicsphere.htmlin a second window and sends control updates withpostMessage.sonicsphere.html-> main audio-reactive sphere renderer.colorsphere.html+colorcontroller.html-> color-focused variant.poetsphere.html+poetcontroller.html-> poetry-related variant.polysphere.html,videosphere.html,venus.html,kurasphere.html-> alternate visualizer experiments.prototypes/-> older or experimental variants.
Shared utility scripts:
js/video_processor.js-> video queueing, frame capture, texture updates.js/message_controller.js-> message handling for live parameter changes.js/audio_controller.js-> audio queue playback helpers and MIDI playback logic.js/sonic_geometries.js-> reusable geometry-building utilities.js/note_analyzer.js-> note/frequency mapping and peak detection helpers.
Layered simulation scaffold (new):
js/layers/audio_engine.js-> emits normalized audio frames (low,mid,high,beat,barPhase) from analyser data.js/layers/sim_compositor.js-> combines one or more simulation plugins into a texture layer for Three.js materials.js/simulations/life_sim.js-> first cellular plugin (Conway-style variant) with audio-reactive speed/rules and beat-triggered spawning.js/simulations/kuramoto_sim.js-> coupled-oscillator "communication" plugin (Kuramoto-inspired local neighbor sync).js/simulations/molecule_graph_sim.js-> molecule communication graph plugin (SDF atom/bond topology with audio-driven diffusion + PubChem fetch support).
Because browsers restrict file/media APIs on file://, run a local server.
npm install
npm startThen open:
http://localhost:8080/controller.html(main controller -> opens visualizer)- or
http://localhost:8080/colorcontroller.html - or
http://localhost:8080/poetcontroller.html
python3 pyserver.pyThen open http://localhost:8000/controller.html.
- Open a controller page.
- Click
Start. - Load audio files (
audio/*,.mid,.midi) and optional videos. - Adjust threshold sliders and other controls to shape the reaction.
- Use keyboard shortcuts in visualizer pages:
htoggle control panelvtoggle video list panel (where supported)
To preload a folder of loops (for example loops/bio1) and reuse it as a startup set:
- Put your loops in
loops/bio1(nested folders are supported). - Build a manifest:
npm run build:vj-set- In
sonicsphere.html, useVideo Set Manifest(sets/bio1.json) and clickLoad Set.
The manifest can also be loaded automatically by the sample export script.
Each loop entry includes transition controls:
{
"url": "loops/bio1/clip01.mp4",
"label": "clip01.mp4",
"transition": {
"type": "fade",
"durationMs": 900,
"holdMs": 8000
}
}Set-level playback can be pingpong (back-and-forth) or loop:
{
"playbackMode": "pingpong"
}You can tune defaults when building:
VJ_HOLD_MS=10000 VJ_TRANSITION_MS=1200 VJ_TRANSITION_TYPE=fade npm run build:vj-setUseful set-build options:
VJ_MAX_LOOPS=20 VJ_PLAYBACK_MODE=pingpong npm run build:vj-setSet manifests can also carry an effect schedule:
{
"effectTimeline": {
"enabled": true,
"phases": [
{ "name": "classic", "durationSec": 16 },
{ "name": "life", "durationSec": 16 },
{ "name": "kuramoto", "durationSec": 16 },
{ "name": "molecule", "durationSec": 16 },
{ "name": "stacked", "durationSec": 16 }
]
}
}When you click Load Set, this schedule is applied automatically.
Set manifests can optionally specify a real molecule source:
{
"moleculeGraph": {
"name": "caffeine",
"names": ["caffeine", "serotonin", "dopamine", "glucose"],
"cycleOnPhaseChange": true
}
}When present, the molecule source is loaded from PubChem automatically.
If names is provided, the set can rotate through the list as phases change.
You can also edit timeline behavior live in sonicsphere.html controls:
Effect phases(comma-separated)sec/phasetimeline onApply FX Timeline
classic preserves the original triangle/polygon visual style before layered variants.
Generate a short sample output recording:
npm run export:sampleBy default it tries to preload sets/bio1.json, injects generated test audio, and
writes artifacts/sample-sonicsphere.webm.
To target a different set manifest:
VJ_SET_MANIFEST=sets/another-set.json npm run export:sampleTo force a specific real molecule during export:
MOLECULE_NAME=caffeine npm run export:sampleFor the 6.5ft x 4.5ft wall target (13:9 aspect ratio), use the dedicated preset:
npm run export:sample:13x9Or override with explicit frame size:
EXPORT_WIDTH=1872 EXPORT_HEIGHT=1296 npm run export:sampleExporter note:
- If source is an audio file (
.wav,.mp3, etc.), audio is muxed into the output video. - If source is MIDI (
.mid/.midi), visuals still render, but export stays silent unless you provide an audio render of that MIDI.
You can also export directly from the UI using Start Export / Stop Export in
sonicsphere.html (uses browser MediaRecorder from the render canvas).
Frequency bands are mapped across a sphere using a golden-ratio-style angular step. When a band crosses its threshold, the corresponding point(s) activate and geometry is generated between active points, producing a live "music topology" effect.
sonicsphere.html now includes a first layered simulation pass:
- Audio analysis ->
HypermuseAudioEngine - Simulation plugin update ->
HypermuseLifeSimulationPlugin+HypermuseKuramotoSimulationPlugin+HypermuseMoleculeGraphSimulationPlugin - Texture composition ->
HypermuseSimulationCompositor - Rendered as an additive "simulation shell" mesh in the scene
This is intended as the base architecture for integrating Morpholib-style and other cellular systems with the same music sync pipeline.
The molecule plugin directly adapts the parseSDF approach used in
fractastical/metajargon and turns bonds into a communication network for signal
propagation.
You can load real molecule data live from controls in sonicsphere.html:
Molecule (PubChem name)input (examples:caffeine,serotonin,dopamine)Load Moleculebutton- status text showing loaded atom/bond counts
sonicsphere.html also runs a timed effect scheduler (while audio is active), cycling
through four profiles about every 16 seconds:
life-> Life-dominant cellular lookkuramoto-> oscillator-dominant sync lookmolecule-> molecule-graph-dominant diffusion lookstacked-> all simulation layers combined
- This repo contains multiple experimental pages with overlapping logic.
- Some scripts are in-progress or partially wired;
controller.html+sonicsphere.htmlis the primary path. - Live control mapping doc:
LIVE_CONTROLS_MIXER.md
The theoretical background is in the Hypermusic repository: https://github.com/fractastical/hypermusic