Skip to content
forked from dkales/dpf-cpp

DPF and PIR based on DPF in C++

Notifications You must be signed in to change notification settings

dimakogan/dpf-cpp

 
 

Repository files navigation

C++ DPF-PIR library

This is a high-performance implementation of private information retrieval (PIR) based on distributed point functions (DPF). As this is a multi-server (more specifically a 2-server) PIR, we need two non-colluding servers with identical databases. For our use case, where this DPF-PIR is being used in a Certificate Transparency (CT) log server, we specialize on databases of SHA-256 hash values, which are stored in a hashdatastore object. This aligns nicely with the use of AVX/AVX2 instructions to speed up calculations. We also make use of AES-NI instructions to create a high-performance PRF.

Executing Microbenchmarks

Example execution of microbenchmarks for a tree with 2^22 elements.

mkdir build && cd build
cmake .. -DCMAKE_BUILD_TYPE=Release
make
./dpf_pir 22

References

TODO: add

About

DPF and PIR based on DPF in C++

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 99.8%
  • CMake 0.2%