6 releases

new 0.1.5 Apr 18, 2025
0.1.4 Apr 16, 2025
0.1.2 May 4, 2024
0.1.1 Feb 3, 2024

#13 in #vision

Download history 12/week @ 2024-12-27 28/week @ 2025-01-03 13/week @ 2025-01-10 3/week @ 2025-01-31 1/week @ 2025-02-07 4/week @ 2025-02-21 15/week @ 2025-02-28 1/week @ 2025-03-14 159/week @ 2025-04-11

159 downloads per month

MIT license

3.5MB
180 lines

Rust crates.io DOI Deploy WASM

butter2d

Pure Rust Implementation of the Butterworth Filter

This crate provides a pure Rust implementation of the Butterworth filter, designed for high-performance spatial frequency filtering of images. It is inspired by and seeks to replicate the functionality of the Butterworth filter as implemented in the popular Python library, scikit-image.

✨ Live WASM Demo

Try the interactive Butterworth filter demo directly in your browser, built with butter2d and WebAssembly:

➡️ Live Demo Link ⬅️

Overview

The Butterworth filter offers a more robust method for applying spatial frequency filters to images compared to traditional FFT/IFFT-based methods. Filters with sharp cutoffs can often lead to the Gibbs phenomenon, where undesirable ringing artifacts appear near edges in the image. This issue is particularly problematic in applications such as EEG experiments (particularly low/mid visual ones that affect P100 amplitudes in the visual cortex) and other scenarios involving low-frequency signals. By providing a smoother transition between the passband and stopband, the Butterworth filter mitigates these effects, making it a preferred choice among vision scientists and image-processing experts.

Usage

Here's a quick example of applying a high-pass Butterworth filter to an image:

cargo add butter2d
use image::{GrayImage, open};
use butter2d::butterworth;

fn main() {
    let img = open("path/to/your/image.png").expect("Failed to open image").to_luma8();
    let cutoff_frequency_ratio = 0.1;
    let high_pass = true;
    let order = 2.0;
    let squared_butterworth = false;
    let npad = 0;
    let filtered_img = butterworth(
        &img, 
        cutoff_frequency_ratio, 
        high_pass, 
        order, 
        squared_butterworth, 
        npad
    );
    filtered_img.save("path/to/save/filtered_image.png").expect("Failed to save filtered image");
}

Dependencies

~9.5MB
~188K SLoC