#bit-manipulation #hamming #distance #benchmark #zero-dependency #auto-vectorization #amenable

hamming-bitwise-fast

A fast, zero-dependency implementation of bitwise Hamming Distance using a method amenable to auto-vectorization

1 stable release

1.0.0 Dec 20, 2024

#75 in Profiling

Download history 121/week @ 2024-12-18 102/week @ 2024-12-25 128/week @ 2025-01-01 21/week @ 2025-01-08

372 downloads per month
Used in image_hasher

MIT/Apache

315KB
57 lines

Hamming Bitwise Fast

A fast, zero-dependency implementation of bitwise Hamming Distance using a method amenable to auto-vectorization.

This started out as a benchmark of various bitwise Hamming distance implementations in Rust. However, after finding that a simple implementation that is amenable to auto-vectorization was comparable, if not faster, than other implementations, I decided to publish it as a crate.

Note: This is for comparing bit-vectors, not for comparing strings.

Usage

use hamming_bitwise_fast::hamming_bitwise_fast;

assert_eq!(hamming_bitwise_fast(&[0xFF; 1024], &[0xFF; 1024]), 0);
assert_eq!(hamming_bitwise_fast(&[0xFF; 1024], &[0x00; 1024]), 1024);

Benchmarks

This uses Criterion to benchmark various Hamming distance implementations:

  • The auto-vectorized implementation in this crate
  • A naive for-loop based implementation
  • A naive iterator based implementation
  • hamming hamming
  • hamming_rs hamming_rs
  • simsimd simsimd

Running the benchmark

cargo bench

Then open the target/criterion/report/index.html file in your browser to view the results.

Results

These were the results running on 3 different types of machines:

2023 MacBook Pro M2 Max

Benchmark results Benchmark results

Linode 2 CPU 4GB

Benchmark results Benchmark results

Fly.io 2 CPU 4GB

Benchmark results Benchmark results

License

This project is licensed under either of the following licenses, at your option:

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps