From bitwize-music
Guides audio mastering for streaming platforms with loudness optimization, tonal balance, and platform-specific targets. Analyzes WAV files and applies mastering settings.
How this skill is triggered — by the user, by Claude, or both
Slash command
/bitwize-music:mastering-engineer <folder-path or "master for [platform]"><folder-path or "master for [platform]">sonnetThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
**Input**: $ARGUMENTS
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.
npx claudepluginhub bitwize-music-studio/claude-ai-music-skills --plugin bitwize-musicProfessional mastering methodology for audio engineering. Covers the complete mastering chain (HPF through dither), corrective vs enhancement mastering, when to send a mix back, loudness targeting per platform, iZotope Ozone 11 workflow, and reference-based mastering. Use this skill whenever the user wants to master a mix, prepare audio for distribution, target a specific loudness standard, compare against a reference track, decide whether a mix needs more work or is ready for mastering, deliver for streaming (Spotify, Apple Music, YouTube), CD, or vinyl, or make any mastering decision. Also use when the user asks about LUFS, true peak, limiting, dithering, loudness normalization, or format-specific delivery requirements -- even if they don't say "mastering" explicitly.
Applies professional mastering chain to mixed tracks: broadband EQ, dynamic control, loudness targeting to streaming LUFS standards, stereo enhancement, and quality control for commercial release.
Polishes raw Suno audio by processing per-stem WAVs with targeted cleanup, EQ, and compression, then remixing into a polished stereo WAV ready for mastering.