Skip to content

Python bindings for the fast integer compression library FastPFor.

License

Notifications You must be signed in to change notification settings

searchivarius/PyFastPFor

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PyPI version Downloads

PyFastPFor

Python bindings for the fast light-weight integer compression library FastPFor: A research library with integer compression schemes. FastPFor is broadly applicable to the compression of arrays of 32-bit integers where most integers are small. The library seeks to exploit SIMD instructions (SSE) whenever possible. This library can decode at least 4 billions of compressed integers per second on most desktop or laptop processors. That is, it can decompress data at a rate of 15 GB/s. This is significantly faster than generic codecs like gzip, LZO, Snappy or LZ4.

Authors

Daniel Lemire, Leonid Boytsov, Owen Kaser, Maxime Caron, Louis Dionne, Michel Lemay, Erik Kruus, Andrea Bedini, Matthias Petri, Robson Braga Araujo, Patrick Damme. Bindings are created by Leonid Boytsov.

Installation

Bindings can be installed locally:

cd python_bindings
pip install -r requirements.txt
sudo setup.py build install

or via pip:

pip install pyfastpfor

Due to some compilation quirks this currently seem to work with GCC only. I will fix it in some not so distant future. You may also need to install Python dev-files. On Ubuntu, for Python 3 you can do it as follows:

sudo apt-get install python3-dev

Documentation

The library supports all the codecs implemented in the original FastPFor library by July 2023. To get a list of codecs, use the function getCodecList.

Typical light-weight compression does not take context into account and, consequently, works well only for small integers. When integers are large, data differencing is a common trick to make integers small. In particular, we often deal with sorted lists of integers, which can be represented by differences between neighboring numbers.

The smallest differences (fine deltas) are between adjacent numbers. Respective differencing and difference inverting functions are delta1'' and prefixSum1''.

However, we can do reasonably well, we compute differences between numbers that are four positions apart (coarse deltas). Such differences can be computed and inverted more efficiently. Respective differencing and difference inverting functions are delta4'' and prefixSum4''.

Examples of three common use scenarios (no differencing, coarse and fine deltas) are outlined in this Python notebook.