QuietOT (to appear at AsiaCrypt 2024) is a lightweight oblivious transfer extension protocol with a non-interactive public-key setup. This implementation is intended to benchmark the performance of QuietOT, and can be used to reproduce a subset of the results reported in Table 2 of the evaluation section.
Directory | |
---|---|
quiet-bipsw/ | Implementation of QuietOT with the BIPSW wPRF. |
quiet-gar/ | Implementation of QuietOT using the GAR wPRF. |
bcmpr-bipsw/ | Implementation of the BCMPR PCF using the BIPSW wPRF. |
other/ | Partial implementations of the BCMPR and OSY pseudorandom correlation functions for benchmarking purposes. |
- OpenSSL
- GNU Make
- Cmake
- Clang
Install dependencies (Ubuntu): | Install dependencies (CentOS): |
---|---|
sudo apt-get install build-essential |
sudo yum groupinstall 'Development Tools' |
sudo apt-get install cmake |
sudo yum install cmake |
sudo apt install libssl-dev |
sudo yum install openssl-devel |
sudo apt install clang |
sudo yum install clang |
On MacOS, use homebrew to install dependencies.
cmake
and clang
can be installed via xcode-select --install
.
OpenSSL can be installed via brew install openssl
or manually.
brew install openssl
xcode-select --install # Installs cmake and clang
Note: If installing OpenSSL manually on Mac, then you will need to update the library path in the Makefiles to point to the correct directory.
Change this -I/opt/homebrew/opt/openssl/include
to -I[PATH]/openssl/include
If you see "library 'crypto' not found", try:
- Check if OpenSSL is properly installed:
brew list openssl
- Verify the OpenSSL path:
brew --prefix openssl
Memory: At least 4GB RAM recommended.
Processor:
- Basic version works on any x86_64 processor.
- AVX512 acceleration requires Intel processor with AVX512 support.
Expected performance:
- With AVX512: ~1,200,000 OT/s.
- Without AVX512: ~500,000 OT/s on Linux.
- Without AVX512: ~1,200,000 OT/s on M1 Mac.
To get QuietOT up and running quickly:
git clone https://github.com/sachaservan/QuietOT
cd QuietOT
cd quiet-bipsw
make && ./bin/test
cd [quiet-bipsw | quiet-gar]
make && ./bin/test
By default, the benchmarks are compiled to generate
make NUM_OTS=[log2 number of OTs]
For example, make NUM_OTS=18
will generate make clean
before recompiling.
Note: trying to generate too many OTs (e.g., setting NUM_OTS=25
will cause performance issues and may cause the benchmarks to stall or crash depending on how much memory you have on your hardware).
Note: requires AVX512 hardware support! (e.g., does not work on M1 Mac)
cd quiet-bipsw
make AVX=1
make && ./bin/test
cd bcmpr-bipsw
make && ./bin/test
cd other
make && ./bin/bench
Simply run the benchmarks as described above on the respective hardware. The output of each benchmark will look something like this:
Took 871.88 ms to generate 1048576 OTs
PASS
...
Took 931.52 ms to generate 1048576 OTs
PASS
******************************************
SUMMARY
Avg. time: 8892.60 ms to generate 1048576 OTs
Performance: 117915.54 OTs/sec
Number of trials: 10
******************************************
Notes:
- Default
NUM_OTS=20
produces the OTs/sec values in the table on the respective hardware. - Public key sizes in the table are derived in the full version of the paper.
- Bits/OT are derived analytically in the paper by analizing the ring size.
- Implement the public-key setup for QuietOT
- Find a way to use SIMD instructions for the GAR variant
- Implement SIMD for ARM architectures
@inproceedings{quietot,
author = "Geoffroy Couteau and
Lalita Devadas and
Srinivas Devadas and
Alexander Koch and
Sacha Servan-Schreiber",
title = "{QuietOT}: Lightweight Oblivious Transfer with a Public-Key Setup",
editor = {Kai-Min Chung and Yu Sasaki},
pages = "197--231",
publisher = {Springer, Singapore},
booktitle = {ASIACRYPT 2024, Part II, LNCS 15485},
year = 2024,
}
We use the super fast Polymur hash for universal hashing. We thank Maxime Bombar for reviewing and providing feedback on the code.
This implementation is intended for research purposes only. The code has NOT been vetted by security experts. As such, no portion of the code should be used in any real-world or production setting!