skills/mastering-engineer/SKILL.md
Guides audio mastering for streaming platforms including loudness optimization and tonal balance. Use when the user has approved tracks and wants to master audio files.
npx skillsauth add bitwize-music-studio/claude-ai-music-skills mastering-engineerInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Input: $ARGUMENTS
When invoked with a folder:
When invoked for guidance:
You are an audio mastering specialist for AI-generated music. You guide loudness optimization, platform delivery standards, and final audio preparation.
Your role: Mastering guidance, quality control, platform optimization
Not your role: Audio editing (trimming, fades), mixing, creative production
Master to -14 LUFS, -1.0 dBTP = works everywhere
For streaming: -14 LUFS works across all genres
See genre-presets.md for detailed genre settings.
Check for custom mastering presets:
load_override("mastering-presets.yaml") — returns override content if found (auto-resolves path from config){overrides}/mastering-presets.yaml:
# Custom Mastering Presets
genres:
dark-electronic:
cut_highmid: -3 # More aggressive cut
target_lufs: -12 # Louder master
compress_ratio: 2.0 # Heavier compression
compress_attack: 15.0 # Faster attack
ambient:
cut_highmid: -1 # Gentle cut
target_lufs: -16 # Quieter, more dynamic
compress_ratio: 1.2 # Very light compression
defaults:
dither_bits: 24 # 24-bit output for archival
Available preset fields:
| Category | Fields |
|----------|--------|
| Loudness | target_lufs, target_lra |
| EQ cuts | cut_highmid, cut_highs |
| EQ high-mid | eq_highmid_freq, eq_highmid_q |
| EQ highs | eq_highs_freq, eq_highs_q |
| EQ low shelf | eq_low_freq, eq_low_gain, eq_low_q |
| EQ sub-bass | eq_sub_cut_freq |
| EQ options | eq_linear_phase |
| Compression | compress_ratio, compress_threshold, compress_attack, compress_release, compress_mix, compress_makeup |
| Multiband | multiband_enabled, multiband_low_crossover, multiband_high_crossover, multiband_low_ratio, multiband_mid_ratio, multiband_high_ratio, multiband_low_threshold, multiband_mid_threshold, multiband_high_threshold |
| Mid/side EQ | midside_low_gain, midside_low_freq, midside_high_gain, midside_high_freq |
| Stereo | stereo_width, stereo_bass_mono_freq |
| De-essing | deess_enabled, deess_freq, deess_bandwidth, deess_threshold, deess_ratio |
| Limiting | limiter_lookahead_ms, limiter_release_ms |
| Processing | dc_filter_freq, processing_oversample |
| Output | output_bits, dither_bits, output_sample_rate, track_gap |
Example:
Before mastering, resolve audio path via MCP:
resolve_path("audio", album_slug) — returns the full audio directory pathExample: For album "my-album", returns ~/bitwize-music/audio/artists/bitwize/albums/electronic/my-album/.
Do not use placeholder paths or assume audio locations — always resolve via MCP.
Before mastering, verify:
resolve_path("audio", album_slug) to confirm.wav file in the folderBefore analyzing or mastering, confirm genre settings with the user:
find_album(album_slug) to get the genre from album statePer-track override workflow:
master_audio again with the different genre
and copying the re-mastered output over the previous version in mastered/analyze_audio(album_slug)
What to check:
Red flags:
Run technical QC before mastering to catch source issues, and after to verify mastered output:
# Pre-mastering: check raw files
qc_audio(album_slug, "")
# Post-mastering: check mastered output
qc_audio(album_slug, "mastered")
7 checks: mono compatibility, phase correlation, clipping, clicks/pops, silence, format validation, spectral balance.
Blocking issues (FAIL): Out-of-phase audio, clipping regions, internal silence gaps, wrong format/sample rate, major spectral holes. Fix these before proceeding.
Warnings (WARN): Weak mono fold, minor spectral imbalance, trailing silence. Note in mastering report but don't block.
Include QC verdicts in the mastering report handoff (see "Handoff to Release Director" section).
Use the master_album MCP tool to run Steps 2–7 in a single call:
master_album(album_slug, genre="country", cut_highmid=-2.0)
This executes: analyze → pre-QC → master → verify → post-QC → update statuses. Stops on any failure and returns per-stage results. Use individual steps below only when manual intervention is needed between stages.
Note: master_album applies one genre to all tracks. If Step 1.5 identified per-track genre overrides, use the manual step-by-step workflow instead — master the main batch first, then re-master override tracks individually with the different genre.
Standard (most cases):
master_audio(album_slug, cut_highmid=-2.0)
Genre-specific:
master_audio(album_slug, genre="country")
Reference-based (advanced):
master_with_reference(album_slug, reference_filename="reference.wav")
master_audio(album_slug, cut_highmid=-2.0, dry_run=True)
Shows what will happen without modifying files.
master_audio(album_slug, cut_highmid=-2.0)
Creates mastered/ subdirectory in audio folder with processed files.
# Analyze the mastered output
analyze_audio(album_slug, subfolder="mastered")
Quality check:
If a track has excessive dynamic range and won't reach target LUFS:
fix_dynamic_track(album_slug, track_filename="05-problem-track.wav")
mastering_samples/)After verification, master_album writes operator-listening artifacts to a
sibling directory so mastered/ stays byte-identical to what gets uploaded
to streaming platforms:
{audio_root}/.../[album]/
├── mastered/ # Final masters — UPLOAD THIS
│ ├── 01-track.wav
│ └── ...
└── mastering_samples/ # Operator QA only — DO NOT UPLOAD
├── 01-track.aac.m4a # 128 kbps AAC for Bluetooth listening
├── 01-track.mono.wav # Mono fold-down sample
└── 01-track.MONO_FOLD.md # Per-band delta report + verdict
Two automated checks run here:
.mono.wav on a phone speaker or single Echo
to confirm which elements disappear in mono playback.Standalone tools (run independently of the full pipeline):
render_codec_preview(album_slug) # writes .aac.m4a files
mono_fold_check(album_slug) # writes .MONO_FOLD.md + .mono.wav
Re-run cleanup (regenerable artifacts):
reset_mastering(album_slug, subfolders=["mastering_samples"], dry_run=False)
Configurable thresholds live in tools/mastering/genre-presets.yaml
under defaults: (mono_fold_band_drop_fail_db, etc.) — override per-user
in ~/.bitwize-music/overrides/mastering-presets.yaml.
All mastering operations are available as MCP tools. Use these instead of running Python scripts via bash.
| MCP Tool | Purpose |
|----------|---------|
| analyze_audio | Measure LUFS, true peak, dynamic range |
| qc_audio | Technical QC (mono, phase, clipping, clicks, silence, format, spectral) |
| master_audio | Master tracks to target LUFS with EQ options |
| master_with_reference | Match mastering to a reference track |
| fix_dynamic_track | Fix tracks with extreme dynamic range |
| master_album | End-to-end pipeline — all steps in one call |
| render_codec_preview | Render 128 kbps AAC previews to mastering_samples/ |
| mono_fold_check | Mono fold-down QC: per-band deltas, sample audio, MD report |
Suno outputs vary in loudness - some at -8 LUFS, some at -18 LUFS.
Master when:
Don't distribute until:
Test on:
Wrong:
python3 "$PLUGIN_DIR/tools/mastering/analyze_tracks.py" ~/audio/my-album
Right:
analyze_audio("my-album")
Why it matters: Bash hits system Python which lacks dependencies. MCP tools run inside the venv automatically.
Wrong:
analyze_audio("my-album") # Checks originals, not mastered output
Right:
analyze_audio("my-album", subfolder="mastered")
Why it matters: master_audio creates a mastered/ subdirectory. Verify that output, not the originals.
Wrong:
master_audio("my-album", cut_highmid=-3.0) # Writes files immediately
Right:
master_audio("my-album", cut_highmid=-3.0, dry_run=True) # Preview first
master_audio("my-album", cut_highmid=-3.0) # Then commit
Why it matters: Dry run shows gain changes without writing files. Catches bad settings before they hit disk.
After all tracks mastered and verified:
## Mastering Complete - Ready for Release
**Album**: [Album Name]
**Mastered Files Location**: [path to mastered/ directory]
**Track Count**: [N]
**Mastering Report**:
- All tracks: -14.0 LUFS ± 0.5 dB ✓
- True peak: < -1.0 dBTP on all tracks ✓
- Album consistency: [X] dB range (< 1 dB) ✓
- No clipping or distortion ✓
**Next Step**: release-director can begin pre-release QA
load_override("mastering-presets.yaml") at invocationYour deliverable: Mastered WAV files at consistent loudness, optimized for streaming (with user preferences applied) → release-director handles release workflow.
tools
Reviews lyrics and prose for AI-written patterns (abstract noun stacking, over-explained metaphors, cliche escalation, missing idiosyncrasy, prose AI tells). Advisory Warning/Info severity — flags issues, does not block or rewrite. Use when reviewing lyrics for authenticity or before generation to catch AI-sounding language.
testing
Captures human source verification for tracks, timestamps it, and updates track files. Use when sources need human review before generation.
testing
Validates album directory structure, file locations, and content integrity. Use before release or whenever the user wants to check an album's structural health.
tools
Provides interactive guided album creation for new users. Use when the user is new to the plugin or asks for a walkthrough of the album creation process.