#lame #mp3 #audio-decoder #decoder #audio #vbr

aloe-mp3

Aloe-MP3 provides software-based MP3 decoding in Rust, supporting frame parsing and VBR data, with integration for LAME encoding. This crate is a translation of the c++ juce module serving the same function.

1 unstable release

Uses new Rust 2024

new 0.1.2 Apr 3, 2025

#6 in #lame


Used in aloe-exports

GPL-3.0 license

1MB
9K SLoC

Aloe-MP3

Aloe-MP3 is a sophisticated Rust library designed for software-based MP3 decoding. It is capable of processing MP3 audio streams by parsing frames, handling variable bit rate (VBR) data, and interfacing with the LAME encoder for encoding tasks.

Overview

Aloe-MP3 is intended for use in professional audio applications where precision and compliance with MP3 specifications are paramount. Users should be aware of the legal implications related to MP3 patents and ensure compliance with their jurisdiction. This crate offers a comprehensive suite of structures and functions for decoding MP3 audio data, enabling audio analysis, manipulation, and encoding via LAME.

Features

  • MP3 Frame Decoding: Utilize the MP3AudioFormat structure for frame decoding with detailed MP3 stream parsing.
  • VBR Support: Decode and interpret variable bit rate tags using Mp3DecoderVBRTagData.
  • LAME Encoder Integration: Seamlessly integrate with the LAME encoder through LameEncoderAudioFormatWriter for enhanced audio format writing capabilities.
  • Advanced DSP: Employ functions such as mp3_decoder_dct36 and mp3_decoder_dct12 for spectral transformations.

Usage

To use Aloe-MP3 in your project, include it in your Cargo.toml:

[dependencies]
aloe-mp3 = "0.1.0"

Example

use aloe_mp3::MP3AudioFormat;

fn main() {
    let mut format = MP3AudioFormat::default();
    // Further decoding and processing code here
}

Important Notes

  • Disclaimer: Users must independently verify the legal implications of using this code in their respective territories.
  • Configuration: Enabling the ALOE_USE_MP3AUDIOFORMAT flag invokes the MP3 decoder at your own risk, agreeing to indemnify Raw Material Software Limited against any legal challenges.

Contribution

Contributions are welcome. Fork this repository, make your changes, and submit a pull request.

License

This project is licensed under the GPL-3.0 License.

README.md generated by an AI model, which may not capture all nuances but should be quite comprehensive.

This crate is a translation of the JUCE module.

JUCE is a c++ software framework for developing high performance audio applications.

Usage falls under the GPLv3 as well as the JUCE commercial license.

See github.com/juce-framework/JUCE and the JUCE license page for details.

This crate is in the process of being translated from c++ to rust. For progress updates, please see the workspacer rust project. designed specifically for rust projects.

Dependencies

~28–38MB
~620K SLoC