home / skills / danielmiessler / personal_ai_infrastructure / audioeditor

AudioEditor skill

/Packs/Utilities/src/AudioEditor

This skill enhances audio quality by transcribing, detecting edits, applying crossfades, and polishing podcasts to remove filler and dead air.

npx playbooks add skill danielmiessler/personal_ai_infrastructure --skill audioeditor

Review the files below or copy the command above to add this skill to your agents.

Files (12)
SKILL.md
4.1 KB
---
name: AudioEditor
description: AI-powered audio/video editing — transcription, intelligent cut detection, automated editing with crossfades, and optional cloud polish. USE WHEN clean audio, edit audio, remove filler words, clean podcast, remove ums, fix audio, cut dead air, polish audio, clean recording, transcribe and edit.
---

# AudioEditor

AI-powered audio/video editing — transcription, intelligent cut detection, automated editing with crossfades, and optional cloud polish.

## Customization

**Before executing, check for user customizations at:**
`~/.claude/PAI/USER/SKILLCUSTOMIZATIONS/AudioEditor/`

If this directory exists, load and apply any PREFERENCES.md, configurations, or resources found there. These override default behavior. If the directory does not exist, proceed with skill defaults.

## Voice Notification

**You MUST send this notification BEFORE doing anything else when this skill is invoked.**

1. **Send voice notification**:
   ```bash
   curl -s -X POST http://localhost:8888/notify \
     -H "Content-Type: application/json" \
     -d '{"message": "Running the WORKFLOWNAME workflow in the AudioEditor skill to ACTION"}' \
     > /dev/null 2>&1 &
   ```

2. **Output text notification**:
   ```
   Running the **WorkflowName** workflow in the **AudioEditor** skill to ACTION...
   ```

**This is not optional. Execute this curl command immediately upon skill invocation.**

## Workflow Routing

| Workflow | Trigger | File |
|----------|---------|------|
| **Clean** | "clean audio", "edit audio", "remove filler words", "clean podcast", "remove ums", "cut dead air", "polish audio" | `Workflows/Clean.md` |

## Pipeline Architecture

```
Audio Input
    |
[Transcribe] Whisper word-level timestamps (insanely-fast-whisper on MPS)
    |
[Analyze] Claude classifies each segment:
    |   KEEP / CUT_FILLER / CUT_FALSE_START / CUT_EDIT_MARKER / CUT_STUTTER / CUT_DEAD_AIR
    |   Distinguishes rhetorical emphasis from accidental repetition
    |
[Edit] ffmpeg executes cuts:
    |   - 40ms qsin crossfades at every edit point
    |   - Room tone extraction and gap filling
    |   - Breath attenuation (50% volume, not removal)
    |
[Polish] (optional) Cleanvoice API final pass:
        - Mouth sound removal
        - Remaining filler detection
        - Loudness normalization

Output: cleaned MP3/WAV
```

## Tools

| Tool | Command | Purpose |
|------|---------|---------|
| **Transcribe** | `bun ~/.claude/skills/Utilities/AudioEditor/Tools/Transcribe.ts <file>` | Word-level transcription via Whisper |
| **Analyze** | `bun ~/.claude/skills/Utilities/AudioEditor/Tools/Analyze.ts <transcript.json>` | LLM-powered edit classification |
| **Edit** | `bun ~/.claude/skills/Utilities/AudioEditor/Tools/Edit.ts <file> <edits.json>` | Execute cuts with crossfades + room tone |
| **Polish** | `bun ~/.claude/skills/Utilities/AudioEditor/Tools/Polish.ts <file>` | Cleanvoice API cloud polish |
| **Pipeline** | `bun ~/.claude/skills/Utilities/AudioEditor/Tools/Pipeline.ts <file> [--polish]` | Full end-to-end pipeline |

## API Keys Required

| Service | Env Var | Where to Get |
|---------|---------|-------------|
| Anthropic (for analyze step) | `ANTHROPIC_API_KEY` | Already set via Claude Code |
| Cleanvoice (for polish step, optional) | `CLEANVOICE_API_KEY` | cleanvoice.ai Dashboard Settings API Key |

## Examples

**Example 1: Clean a podcast recording**
```
User: "clean up the audio on this podcast file"
-> Invokes Clean workflow
-> Runs full pipeline: transcribe -> analyze -> edit
-> Outputs cleaned MP3 with filler words, stutters, and dead air removed
```

**Example 2: Preview edits before applying**
```
User: "show me what edits you'd make to this recording"
-> Invokes Clean workflow with --preview flag
-> Transcribes and analyzes, shows proposed edits without modifying audio
-> User reviews edit list, then runs again to apply
```

**Example 3: Aggressive clean with cloud polish**
```
User: "aggressively clean this audio and polish it"
-> Invokes Clean workflow with --aggressive --polish flags
-> Tighter thresholds for filler detection
-> Cleanvoice API pass for mouth sounds and normalization
```

Overview

This skill provides AI-powered audio and video cleaning workflows: fast word-level transcription, LLM edit classification, automated cuts with crossfades, and an optional cloud polish pass. It focuses on removing filler words, false starts, stutters, and dead air while preserving natural emphasis and breathing. The output is a cleaned MP3 or WAV ready for publishing.

How this skill works

On invocation the pipeline transcribes audio with a whisper backend to obtain word-level timestamps, then uses an LLM to classify each segment as keep or various cut types (filler, false start, stutter, dead air). An edit engine applies precise cuts using short crossfades, room-tone gap filling, and breath attenuation. Optionally, a cloud polishing step runs through a service to remove mouth noises and normalize loudness.

When to use it

  • Preparing podcast episodes for release (remove ums, stutters, and dead air).
  • Cleaning interview or lecture recordings for transcription and publishing.
  • Trimming false starts and filler words from voiceovers and demos.
  • Creating a preview of proposed edits before committing changes.
  • Applying an aggressive cleanup pass with cloud polish for final master output.

Best practices

  • Run the required voice notification before any processing so systems and stakeholders are informed.
  • Preview edits first with the preview flag to review proposed cuts before applying them.
  • Keep original recordings safe; edit outputs are new files (non-destructive workflow).
  • Use aggressive thresholds only when natural repetitions or rhetorical emphasis are not needed.
  • Provide clean recordings when possible—less background noise improves transcription and classification.

Example use cases

  • Clean a multi-host podcast episode to remove filler words and tighten pacing.
  • Preview and accept suggested edits for a recorded interview before exporting.
  • Run an aggressive clean + polish to prepare a marketing voiceover for broadcast.
  • Remove long dead-air gaps from a lecture recording while preserving pauses for emphasis.

FAQ

Is any cloud API required?

The core pipeline runs locally (transcribe, analyze, edit). Cleanvoice cloud polish is optional and requires an API key if used.

Can I review edits before they are applied?

Yes. Use the preview mode to generate an edits list without modifying the audio, review it, then run the full pipeline to apply changes.

What types of edits are performed automatically?

The system classifies and can remove filler words, false starts, stutters, edit markers, and dead air, and applies short crossfades, room-tone filling, and breath attenuation.