#dsp #convolution #audio #impulseresponse

aloe-convolution-demo

A Rust library for performing audio convolution using impulse responses, with GUI components. This crate is a translation of the c++ juce module serving the same function.

1 unstable release

Uses new Rust 2024

new 0.1.1 Apr 3, 2025

#19 in #convolution


Used in aloe-exports

GPL-3.0 license

1MB
7.5K SLoC

Aloe Convolution Demo

Aloe Convolution Demo is a Rust crate designed for audio signal processing, specifically convolution operations which are pivotal in digital signal processing used in audio effects, reverberation, and emulations of acoustic spaces. It provides an efficient and flexible structure to load impulse responses and apply them to audio data streams.

Crate Functionality

The primary structs in this library are ConvolutionDemo and ConvolutionDemoDSP. These functionalities include:

  • ConvolutionDemo: Manages audio file input and GUI components.
  • ConvolutionDemoDSP: Handles digital signal processing, preparing and processing the audio signal contexts, and enabling bypass operation.

Key Components

  • AudioFileReaderComponent: Reads audio data from files to supply them to the convolution processor.
  • MemoryBlock and BufferTransfer: Utilities for managing audio data buffers needed to process convolution operations efficiently.
  • Convolution: The core processing engine that applies impulse responses to input audio data.
  • ChoiceParameter: Helps manage user-selectable parameters, such as choosing cabinets for guitar amp simulation.

Usage

The typical usage involves preparing the DSP component with specific processing specifications, managing audio file reading, and configuring the convolution engine to respond to real-time signal processing commands:

  • Prepare and Process: Modify the sample rate and load impulse responses efficiently to apply convolution effects accurately.
  • Reset and Parameter Updates: Handle changes in configurations dynamically, enabling seamless transition and update of DSP operation parameters.

Installation

Include the following in your Cargo.toml:

[dependencies]
aloe-convolution-demo = "0.1.0"

Contribution

Contributions are welcome. Please open issues to propose changes or report bugs. Visit the repository for more details.


Please note that this README file was generated by an AI model and may not be 100% accurate, however it should be a comprehensive overview.

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

~40MB
~643K SLoC