Crates.io | sndfile |
lib.rs | sndfile |
version | 0.1.1 |
source | src |
created_at | 2020-04-05 17:20:32.967147 |
updated_at | 2022-04-29 15:26:08.621668 |
description | A library for reading and writing audio files. |
homepage | |
repository | https://github.com/Xeiron/sndfile.rs |
max_upload_size | |
id | 226634 |
size | 57,798 |
A safe rust wrapper of libsndfile.
With this crate, you can read or save audio files.
sndfile.rs is available on crates.io.
With minimal features:
[dependencies]
sndfile = "0.1"
With ndarray supports:
[dependencies.sndfile]
version = "0.1"
features = ["ndarray_features"]
...and see the docs for how to use it.
extern crate sndfile;
extern crate ndarray;
fn main() {
use sndfile::*;
let mut snd = sndfile::OpenOptions::ReadOnly(ReadOptions::Auto).from_path(
"/mnt/st4t_0/tuxzz/muz/muz0/Call My Name/13.Loow.flac"
).unwrap();
let data: ndarray::Array2<f32> = snd.read_all_to_ndarray().unwrap();
let samplerate = snd.get_samplerate();
let n_frame = snd.len().unwrap();
let n_channels = snd.get_channels();
let title = snd.get_tag(TagType::Title).unwrap();
println!("Loaded song `{}`:", title);
println!(" Length: {:.2} seconds", n_frame as f64 / samplerate as f64);
println!(" Sample rate: {} Hz", samplerate);
println!(" Channel count: {}", n_channels);
println!(" DC offset = {}", data.mean().unwrap());
}
/*
== Expected output ==
Loaded song `Loow`:
Length: 277.06 seconds
Sample rate: 44100 Hz
Channel count: 2
DC offset = 0.00018921464
*/
Licensed under of