bitvec: Space-efficient bit vectors
A newtype over Bool with a better Vector instance: 8x less memory, up to 1000x faster.
The vector
package represents unboxed arrays of Bools
spending 1 byte (8 bits) per boolean.
This library provides a newtype wrapper Bit and a custom instance
of an unboxed Vector, which packs bits densely,
achieving an 8x smaller memory footprint.
The performance stays mostly the same;
the most significant degradation happens for random writes
(up to 10% slower).
On the other hand, for certain bulk bit operations
Vector Bit is up to 1000x faster than Vector Bool.
Thread safety
Data.Bit is faster, but writes and flips are thread-unsafe. This is because naive updates are not atomic: they read the whole word from memory, then modify a bit, then write the whole word back.
Data.Bit.ThreadSafe is slower (up to 20%), but writes and flips are thread-safe.
Similar packages
array is memory-efficient for
Bool, but lacks a handyVectorinterface and is not thread-safe.
[Skip to Readme]
Flags
Manual Flags
| Name | Description | Default |
|---|---|---|
| libgmp | Link against the GMP library for the ultimate performance of
| Disabled |
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- bitvec-1.1.3.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
- No Candidates
| Versions [RSS] | 0.1, 0.1.0.1, 0.1.0.2, 0.1.1.0, 0.2.0.0, 0.2.0.1, 1.0.0.0, 1.0.0.1, 1.0.1.0, 1.0.1.1, 1.0.1.2, 1.0.2.0, 1.0.3.0, 1.1.0.0, 1.1.1.0, 1.1.2.0, 1.1.3.0, 1.1.4.0, 1.1.5.0 (info) |
|---|---|
| Change log | changelog.md |
| Dependencies | base (>=4.9 && <5), bytestring (>=0.10), deepseq, ghc-bignum, integer-gmp, primitive (>=0.5), vector (>=0.11 && <0.14) [details] |
| Tested with | ghc ==8.0.2, ghc ==8.2.2, ghc ==8.4.4, ghc ==8.6.5, ghc ==8.8.1, ghc ==8.8.2, ghc ==8.8.4, ghc ==8.10.7, ghc ==9.0.1, ghc ==9.2.1 |
| License | BSD-3-Clause |
| Copyright | 2019-2022 Andrew Lelechenko, 2012-2016 James Cook |
| Author | Andrew Lelechenko <andrew.lelechenko@gmail.com>, James Cook <mokus@deepbondi.net> |
| Maintainer | Andrew Lelechenko <andrew.lelechenko@gmail.com> |
| Uploaded | by Bodigrim at 2022-06-19T21:30:49Z |
| Category | Data, Bit Vectors |
| Home page | https://github.com/Bodigrim/bitvec |
| Source repo | head: git clone git://github.com/Bodigrim/bitvec.git |
| Distributions | Arch:1.1.5.0, Fedora:1.1.5.0, LTSHaskell:1.1.5.0, NixOS:1.1.5.0, Stackage:1.1.5.0, openSUSE:1.1.5.0 |
| Reverse Dependencies | 20 direct, 8566 indirect [details] |
| Downloads | 18152 total (96 in the last 30 days) |
| Rating | 2.25 (votes: 2) [estimated by Bayesian average] |
| Your Rating | |
| Status | Docs available [build log] Last success reported on 2022-06-19 [all 1 reports] |