#latency #audio-synthesis #synthesis #audio #signalprocessing #rust

aloe-ex-audio

Aloe Ex Audio is a cutting-edge Rust-based library crafted to handle intricate audio processing and synthesis. It includes tools for latency measurement, audio device management, and implements the Karplus-Strong algorithm for string sound synthesis. 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

#2 in #signalprocessing


Used in aloe-ex

GPL-3.0 license

3.5MB
30K SLoC

Aloe Ex Audio

Aloe Ex Audio is a powerful Rust crate designed to facilitate advanced audio processing and manipulation. It serves as a solid foundation for audio-based applications, featuring simulation of musical strings and management of audio device settings. It integrates structured audio components to deliver precise and efficient sound solutions.

Features

  • Audio Signal Processing: Implements core functionalities for processing audio signals, including phase and amplitude control.

  • Karplus-Strong Algorithm: Simulates plucked string sounds using the renowned Karplus-Strong synthesis method, ideal for string sound simulation.

  • Latency Testing: Provides comprehensive tools to test audio latency, useful for synchronizing input and output devices with advanced precision.

  • Audio Device Management: Facilities to handle different audio devices, ensuring robust audio input/output management.

  • Dynamic UI Integration: Interface components that support real-time audio analysis and control, offering GUI integration for interactive audio demos.

Data Structures

  • AudioAppDemo: Configures and manages an audio application, handling various sound parameters.

  • StringSynthesizer: Manages a simple audio synthesizer for creating plucked string sounds with decay and amplitude control.

  • LatencyTester: Utilities to assess audio latency and manage synchronized audio input-output operations.

Example Usage

let mut demo = AudioAppDemo::default();
demo.prepare_to_play(512, 44100.0);
demo.get_next_audio_block(&mut buffer_info);

Installation

Add the following to your Cargo.toml:

[dependencies]
aloe-ex-audio = "0.1.0"

License

Licensed under GPL-3.0. See LICENSE.txt for details.


This README was generated by an AI model and may not be 100% accurate; however, it should provide substantial information and guidance on using this crate.

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

~30–44MB
~629K SLoC