mp3rgain
Lossless MP3 volume adjustment - a modern mp3gain replacement written in Rust
mp3rgain adjusts MP3 volume without re-encoding by modifying the global_gain field in each frame's side information. This preserves audio quality while achieving permanent volume changes.
Features
- Lossless & Reversible: No re-encoding, all changes can be undone
- ReplayGain: Track and album gain analysis with AAC/M4A support
- Zero dependencies: Single static binary (no ffmpeg, no mp3gain)
- Cross-platform: macOS, Linux, Windows (x86_64 and ARM64)
- mp3gain compatible: Drop-in replacement with identical CLI
- GUI Application: Native desktop app for drag-and-drop workflow
Installation
macOS
Windows
scoop bucket add mp3rgain https://github.com/M-Igashi/scoop-bucket
scoop install mp3rgain
Linux
# Arch Linux (AUR)
# Nix/NixOS
Cargo
Manual Download
Download binaries from GitHub Releases.
Quick Start
# Normalize a single track (ReplayGain)
# Normalize an album
# Manual gain adjustment (+3.0 dB)
# Undo changes
# Show file info
GUI Application
A native GUI application (mp3rgui) is available for users who prefer a graphical interface.
Features: Drag-and-drop, track/album analysis, one-click gain application, clipping warnings, progress indicators.
Download: GitHub Releases
mp3rgui-macos-universal.tar.gz(macOS)mp3rgui-linux-x86_64.tar.gz(Linux)mp3rgui-windows-x86_64.zip(Windows)
macOS users: If you see "mp3rgui cannot be opened" warning, run:
Command-Line Options
| Option | Description |
|---|---|
-r |
Apply Track gain (ReplayGain) |
-a |
Apply Album gain (ReplayGain) |
-g <i> |
Apply gain of i steps (1 step = 1.5 dB) |
-d <n> |
Modify target dB level (use with analysis) |
-u |
Undo gain changes |
-k |
Prevent clipping |
-R |
Process directories recursively |
-n |
Dry-run mode |
-o [fmt] |
Output format: text, json, tsv (default: tsv if no argument) |
Run mp3rgain -h for the full list of options.
Integration
beets
mp3rgain works as a drop-in replacement for mp3gain in the beets replaygain plugin:
# config.yaml
replaygain:
backend: command
command: mp3rgain
Documentation
- Security - Security improvements over original mp3gain (CVE-2021-34085, CVE-2019-18359)
- Compatibility Report - Verification against original mp3gain
- Technical Comparison - Comparison with similar tools
Why mp3rgain?
The original mp3gain has been unmaintained since ~2015. mp3rgain is a modern, memory-safe replacement that works on current systems including Windows 11, macOS, and Linux.
ReplayGain Algorithm
mp3rgain implements the original ReplayGain 1.0 algorithm, the same as the classic mp3gain/aacgain:
- Equal-loudness filter (Yule-Walker + Butterworth high-pass)
- RMS calculation in 50ms windows
- 95th percentile statistical analysis
- 89 dB reference level
This is a deliberate choice to maintain full compatibility with the original mp3gain. Loudness values will differ from tools using EBU R128/LUFS-based analysis (such as foobar2000's ReplayGain scanner, loudgain, or ffmpeg's loudnorm filter), which use a -23 LUFS reference level.
Library Usage
use ;
use Path;
let frames = apply_gain?; // +3.0 dB
let info = analyze?;
Contributing
Contributions welcome! See CONTRIBUTING.md.
License
MIT License - see LICENSE.
See Also
- Original mp3gain
- headroom - DJ audio loudness optimizer