8 releases (4 breaking)
0.5.0 | Jan 24, 2022 |
---|---|
0.4.1-alpha.0 | Jan 24, 2022 |
0.4.0 | Jun 26, 2021 |
0.3.1 | Feb 8, 2021 |
0.1.0 | Dec 25, 2020 |
#946 in Audio
18MB
133K
SLoC
Contains (static library, 5MB) libc.a, (static library, 605KB) libgcc.a, (static library, 690KB) libmbedtls.a, (ar library, 350KB) WS2_32.Lib, (ar library, 350KB) WS2_32.Lib, (static library, 430KB) libat.a and 24 more.
Rustchord (Colorchord2 bindings for Rust)
These are simple bindings around the Notefinder construct in Colorchord. Colorchord is an amazing piece of software written by CNLohr. I've been wanting to use the algorithm in different projects and decided to write a easy Rust bindings that allows you to run the algorithm against audio acquired in Rust.
Using the binding
The Notefinder expects to read samples from a ringbuffer in order to generate the bucketed notes. For this reason you need to provide a simple ringbuffer with audio samples in f32
format. The audioinput
showcases how to do this.
First create a new instance of the Notefinder with the samplerate that's expected:
let mut notefinder = rustchord::Notefinder::new(48000)
Then provide samples in a buffer as you process them:
notefinder.run(&samplevec)
After Notefinder has ran you can get the folded notes by doing:
notefinder.get_notes()
Configuring Notefinder
You can configure parameters of the Notefinder using the set_ methods. For example, to change the input amplification you can use:
notefinder.set_amplification(10.0)
Building from Git
git clone https://github.com/coral/rustchord.git
cd rustchord
git submodule update --init --recursive
cargo build
To run the audio input example, just do
cargo run --example audioinput
License
ColorChord is Copyright 2015 Charles Lohr, Under the MIT/x11 License.
All other code is licensed under the MIT license.
Dependencies
~3–5.5MB
~119K SLoC