Go to file
lif 7b8f1095d4 WIP hacks to enable no_std and no alloc 2020-11-28 02:11:23 -08:00
benches Fix Cargo benchmarks 2017-02-07 12:37:20 +01:00
docs Describe what Claxon is in the readme 2017-09-09 11:26:16 +02:00
examples Merge new metadata support 2017-10-19 21:40:18 +02:00
fuzz Bump version to 0.4.3 2020-08-09 12:05:40 +02:00
src WIP hacks to enable no_std and no alloc 2020-11-28 02:11:23 -08:00
tests Add test for empty Vorbis comment 2019-09-11 22:19:10 +02:00
testsamples Fix integer underflow when reading Vorbis comments 2019-09-16 20:26:42 +02:00
tools Try fuzzing on Travis once more 2019-05-19 19:37:52 +02:00
.gitignore Put Cargo.lock under source control 2017-09-03 12:09:28 +02:00
.travis.yml Try fuzzing on Travis once more 2019-05-19 19:37:52 +02:00
Cargo.lock Bump version to 0.4.3 2020-08-09 12:05:40 +02:00
Cargo.toml WIP hacks to enable no_std and no alloc 2020-11-28 02:11:23 -08:00
changelog.md Bump version to 0.4.3 2020-08-09 12:05:40 +02:00
contributing.md Update code of conduct 2018-03-27 22:57:18 +02:00
license change license to Apache 2.0 2016-05-29 16:13:07 +02:00
readme.md Add new Claxon-vs-libflac benchmark results 2018-08-31 16:29:33 +02:00

readme.md

Claxon

A FLAC decoding library in Rust.

Build Status Crates.io version Changelog Documentation

Claxon is a FLAC decoder written in pure Rust. It has been fuzzed and verified against the reference decoder for correctness. Its performance is similar to the reference decoder.

Example

The following example computes the root mean square (RMS) of a FLAC file:

let mut reader = claxon::FlacReader::open("testsamples/pop.flac").unwrap();
let mut sqr_sum = 0.0;
let mut count = 0;
for sample in reader.samples() {
    let s = sample.unwrap() as f64;
    sqr_sum += s * s;
    count += 1;
}
println!("RMS is {}", (sqr_sum / count as f64).sqrt());

More examples can be found in the examples directory. For a simple example of decoding a FLAC file to wav with Claxon and Hound, see decode_simple.rs. A more efficient way of decoding requires dealing with a few details of the FLAC format. See decode.rs for an example.

Performance

These are the times to decode 5 real-world FLAC files to wav, average and standard deviation of 11 runs, normalized to version 1.3.2 of the reference implementation. Measurements were done on a Skylake i7. Claxon was compiled with Rust 1.26.0.

Decoder Time / reference
Claxon 1.10 ± 0.01
libflac 1.00 ± 0.01

Note that for decent performance, Claxon should be compiled with -C codegen-units=1 on Rust ≥ 1.24.0. Not passing this RUSTFLAG can cause as much as a 45% increase in running time.

Contributing

Contributions in the form of bug reports, feature requests, or pull requests are welcome. See contributing.md.

License

Claxon is licensed under the Apache 2.0 license. It may be used in free software as well as closed-source applications, both for commercial and non-commercial use under the conditions given in the license. If you want to use Claxon in your GPLv2-licensed software, you can add an exception to your copyright notice. Please do not open an issue if you disagree with the choice of license.