Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music. --- name: strudel-music description: "Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music." user-invocable: true metada Capability contract not published. No trust telemetry is available yet. Last updated 2/24/2026.
Freshness
Last checked 2/24/2026
Best For
strudel-music is best for general automation workflows where OpenClaw compatibility matters.
Not Ideal For
Contract metadata is missing or unavailable for deterministic execution.
Evidence Sources Checked
editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack
Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music. --- name: strudel-music description: "Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music." user-invocable: true metada
Public facts
4
Change events
1
Artifacts
0
Freshness
Feb 24, 2026
Capability contract not published. No trust telemetry is available yet. Last updated 2/24/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Feb 24, 2026
Vendor
Karmaterminal
Artifacts
0
Benchmarks
0
Last release
Unpublished
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Capability contract not published. No trust telemetry is available yet. Last updated 2/24/2026.
Setup snapshot
git clone https://github.com/karmaterminal/strudel-music.gitSetup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Karmaterminal
Protocol compatibility
OpenClaw
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
Parameters
bash
# Render + convert + stream node src/runtime/offline-render-v2.mjs "assets/compositions/<name>.js" /tmp/<name>.wav 16 120 ffmpeg -i /tmp/<name>.wav -ar 48000 -ac 2 /tmp/<name>-48k.wav -y node scripts/vc-play.mjs /tmp/<name>-48k.wav
text
samples/
my-kit/
kick-soft.wav → s("my-kit").n(0)
kick-hard.wav → s("my-kit").n(1)
snare-tight.wav → s("my-kit").n(2)
snare-loose.wav → s("my-kit").n(3)bash
npm run setup # Installs all deps + downloads dirt-samples (~11MB, CC-licensed)
javascript
sound("bd sd cp hh").bank("RolandTR909")
sound("bd sd hh oh").bank("LinnDrum")ini
# %USERPROFILE%\.wslconfig [wsl2] networkingMode=mirrored
javascript
setcpm(120/4) // 120 BPM
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music. --- name: strudel-music description: "Compose, render, and play music using Strudel live-coding patterns. Usage: /strudel <prompt> — describe what you want to hear (mood, scene, genre, instruments). /strudel play <name> — play a saved composition in Discord VC. /strudel samples — manage sample packs. /strudel list — show available compositions. Like /imagine for Midjourney, but for music." user-invocable: true metada
Like /imagine for Midjourney, but for music. Compose, render, and stream music using Strudel live-coding patterns — entirely offline, no browser required.
When a user invokes /strudel, route based on intent:
/strudel <prompt> — Compose from descriptionGenerate a Strudel pattern from a natural language prompt. The agent interprets the mood, instruments, tempo, and structure, writes a composition file, renders it to audio, and posts the result.
Examples:
/strudel dark ambient tension, low drones, sparse percussion, 65bpm/strudel upbeat tavern music with fiddle and drums/strudel lo-fi chill beats to study to/strudel epic battle music, brass and timpani, 140bpm/strudel a theme for a character named Cael — curious, quick, a little dangerousWorkflow:
.js composition file using Strudel pattern syntaxnode src/runtime/offline-render-v2.mjs <file> <output.wav> <cycles> <bpm>ffmpeg -i output.wav -c:a libmp3lame -q:a 2 output.mp3/strudel play <name> — Play in Discord VCStream a saved composition into the user's Discord voice channel.
# Render + convert + stream
node src/runtime/offline-render-v2.mjs "assets/compositions/<name>.js" /tmp/<name>.wav 16 120
ffmpeg -i /tmp/<name>.wav -ar 48000 -ac 2 /tmp/<name>-48k.wav -y
node scripts/vc-play.mjs /tmp/<name>-48k.wav
/strudel list — Show available compositionsList all .js files in assets/compositions/ with their metadata (@title, @mood, @tempo).
/strudel samples — Manage sample packsSubcommands:
/strudel samples list — show installed sample directories and counts/strudel samples download — re-run scripts/download-samples.sh (idempotent — skips if already present)/strudel samples add <url> — download a sample pack from a URL (ZIP/tar containing WAV directories)/strudel samples add <path> — symlink or copy a local directory into samples/How custom samples work:
Drop any directory of WAV files into samples/<name>/. They're automatically discovered by the renderer. Use them in patterns with s("<name>"). Variations are indexed by filename sort order — access with s("<name>").n(3).
Example: if you have an Ableton drum rack exported as WAVs:
samples/
my-kit/
kick-soft.wav → s("my-kit").n(0)
kick-hard.wav → s("my-kit").n(1)
snare-tight.wav → s("my-kit").n(2)
snare-loose.wav → s("my-kit").n(3)
/strudel concert <name> [name2] [name3] ... — Play a setlistRender and stream multiple compositions sequentially into Discord VC.
npm run setup
# Installs all deps + downloads dirt-samples (~11MB, CC-licensed)
That's it. First render: npm run test:render
The skill ships with dirt-samples (96 WAVs: kicks, snares, hats, toms, 808s). For richer sounds, add sample packs:
CC0 / Free packs (just download and drop in samples/):
Your own packs: Export from any DAW (Ableton, FL Studio, M8 tracker, etc.) as WAV directories. Strudel doesn't care where they came from — it's just WAV files in folders.
Named banks (Strudel built-in, requires CDN access):
sound("bd sd cp hh").bank("RolandTR909")
sound("bd sd hh oh").bank("LinnDrum")
If running on WSL2 and streaming to Discord VC, enable mirrored networking:
# %USERPROFILE%\.wslconfig
[wsl2]
networkingMode=mirrored
Then wsl --shutdown and relaunch. Without this, WSL2's NAT breaks Discord's UDP voice protocol — the bot joins the channel but no audio flows because IP discovery packets can't traverse the NAT return path. Mirrored mode eliminates the NAT by putting WSL2 directly on the host's network stack.
This only affects VC streaming. Offline rendering and file posting work in any networking mode.
The offline renderer uses node-web-audio-api (Rust-based Web Audio for Node.js) for real audio synthesis:
@strudel/core + @strudel/mini + @strudel/tonal parse pattern code into timed "haps"OfflineAudioContext.startRendering() produces complete audioNote on mini notation: The renderer explicitly calls setStringParser(mini.mini) after import because Strudel's npm dist bundles duplicate the Pattern class across modules. Same class of bug as openclaw#22790.
setcpm(120/4) // 120 BPM
stack(
s("bd sd bd sd"), // drums
note("c3 g3").s("sawtooth").lpf(800), // bass
n("0 2 4 7").scale("C:minor").s("triangle") // melody
)
"a b c d" — sequence (one per beat)"[a b]" — subdivide (two in one beat)"<a b c>" — alternate per cycle"a*3" — repeat"~" — rest/silence.slow(2) / .fast(2) — time stretch.euclid(3,8) — Euclidean rhythm.lpf(sine.range(400, 4000).slow(8)) // filter sweep
.gain(sine.range(0.1, 0.2).slow(9)) // breathing volume
.pan(perlin.range(0.2, 0.8)) // organic stereo
.room(0.5).roomsize(4) // reverb
.delay(0.3).delaytime(0.25) // delay
.attack(0.01).decay(0.2).sustain(0.5).release(0.3) // ADSR
let intro = stack(pad, noise)
let verse = stack(drums, bass, melody)
let chorus = stack(drums, bass, melody, lead)
arrange(
[8, intro],
[16, verse],
[8, chorus]
).cpm(120/4)
| Mood | Tempo | Key/Scale | Character | |------|-------|-----------|-----------| | tension | 60-80 | minor/phrygian | Low cutoff, sparse, drones | | combat | 120-160 | minor | Heavy drums, fast, distorted | | exploration | 80-100 | dorian/mixolydian | Open, delay, mid energy | | peace | 60-80 | pentatonic/major | Warm, slow, ambient | | mystery | 70-90 | whole tone | Reverb, sparse, unpredictable | | victory | 110-130 | major | Bright, fanfare, full | | sorrow | 48-65 | minor | Sustained pads, minimal | | ritual | 45-60 | dorian | Organ drones, chant |
See references/mood-parameters.md for the full tree with transitions and leitmotifs.
See references/production-techniques.md for advanced techniques (breathing, shimmer, earth pressure).
src/runtime/
offline-render-v2.mjs — Core offline renderer
smoke-test.mjs — 12-point verification test
scripts/
download-samples.sh — Download dirt-samples (idempotent)
vc-play.mjs — Stream audio to Discord VC
samples/ — Sample packs (gitignored, downloaded on demand)
assets/compositions/ — Saved compositions
references/ — Mood trees, techniques, architecture docs
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
missing
Auth
None
Streaming
No
Data region
Unspecified
Protocol support
Requires: none
Forbidden: none
Guardrails
Operational confidence: low
curl -s "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/snapshot"
curl -s "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/contract"
curl -s "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Do not use if
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Rank
70
AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
The Frontend for Agents & Generative UI. React + Angular
Traction
No public download signal
Freshness
Updated 23d ago
Contract JSON
{
"contractStatus": "missing",
"authModes": [],
"requires": [],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": null,
"outputSchemaRef": null,
"dataRegion": null,
"contractUpdatedAt": null,
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"OPENCLEW"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_OPENCLEW",
"generatedAt": "2026-04-17T04:09:41.641Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "OPENCLEW",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Karmaterminal",
"href": "https://github.com/karmaterminal/strudel-music",
"sourceUrl": "https://github.com/karmaterminal/strudel-music",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/karmaterminal-strudel-music/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to strudel-music and adjacent AI workflows.