#byte-slice #algorithm #utf-8 #counting #points #count #occurrence

no-std bytecount

count occurrences of a given byte, or the number of UTF-8 code points, in a byte slice, fast

19 releases

0.6.8 Apr 19, 2024
0.6.7 Oct 24, 2023
0.6.3 Jun 1, 2022
0.6.2 Dec 1, 2020
0.1.4 Oct 4, 2016

#17 in Algorithms

Download history 332811/week @ 2024-08-27 448552/week @ 2024-09-03 391384/week @ 2024-09-10 358028/week @ 2024-09-17 401593/week @ 2024-09-24 402796/week @ 2024-10-01 410879/week @ 2024-10-08 548953/week @ 2024-10-15 476635/week @ 2024-10-22 437537/week @ 2024-10-29 439189/week @ 2024-11-05 494907/week @ 2024-11-12 462560/week @ 2024-11-19 343994/week @ 2024-11-26 432313/week @ 2024-12-03 406252/week @ 2024-12-10

1,724,704 downloads per month
Used in 1,605 crates (91 directly)

Apache-2.0/MIT

43KB
939 lines

bytecount

Counting bytes really fast

Continuous integration Windows build status Current Version License: Apache 2.0/MIT

This uses the "hyperscreamingcount" algorithm by Joshua Landau to count bytes faster than anything else. The newlinebench repository has further benchmarks for old versions of this repository.

To use bytecount in your crate, if you have cargo-edit, just type cargo add bytecount in a terminal with the crate root as the current path. Otherwise you can manually edit your Cargo.toml to add bytecount = 0.6.8 to your [dependencies] section.

In your crate root (lib.rs or main.rs, depending on if you are writing a library or application), add extern crate bytecount;. Now you can simply use bytecount::count as follows:

extern crate bytecount;

fn main() {
    let mytext = "some potentially large text, perhaps read from disk?";
    let spaces = bytecount::count(mytext.as_bytes(), b' ');
    ..
}

bytecount supports two features to make use of modern CPU's features to speed up counting considerably. To allow your users to use them, add the following to your Cargo.toml:

[features]
runtime-dispatch-simd = ["bytecount/runtime-dispatch-simd"]
generic-simd = ["bytecount/generic-simd"]

The first, runtime-dispatch-simd, enables detection of SIMD capabilities at runtime, which allows using the SSE2 and AVX2 codepaths, but cannot be used with no_std.

Your users can then compile with runtime dispatch using:

cargo build --release --features runtime-dispatch-simd

The second, generic-simd, uses std::simd and #![feature(portable_simd)] to provide a fast architecture-agnostic SIMD codepath, but requires running on nightly.

Your users can compile with this codepath using:

cargo build --release --features generic-simd

Building for a more specific architecture will also improve performance. You can do this with

RUSTFLAGS="-C target-cpu=native" cargo build --release

The scalar algorithm is explained in depth here.

Note: Versions until 0.4.0 worked with Rust as of 1.20.0. Version 0.5.0 until 0.6.0 requires Rust 1.26 or later, and at least 1.27.2 to use SIMD. Versions from 0.6.0 require Rust 1.32.0 or later.

License

Licensed under either of at your discretion:

No runtime deps