-
Notifications
You must be signed in to change notification settings - Fork 16
Cingulata
Cingulata, previously known as Armadillo (eprint), is a compiler that translates high-level programs written in C++ (against the Cingulata API) into circuits to be executed using FHE. It bundles its own implementation of the BFV scheme, and also has partial support for the TFHE library.
The compiler is bundled with a runtime environment that supports an offline mode (BFV only) and an online mode (TFHE only). In the offline mode, the given input C++ program is transformed into its equivalent Boolean circuit, optimized by the ABC tool, and finally executed. The online mode can be compared to an on-the-fly execution in that the input program is executed directly using a low-level implementation of the TFHE scheme.
The following describes how programs for BFV are compiled by Cingulata. The whole compilation process is fully automated using cmake/make files, and as such the following steps are enough to build Cingulata including its examples:
git clone https://github.com/CEA-LIST/Cingulata.git
cd Cingulata
mkdir build; cd "$_"
cmake ..
make
As an example for the following explanation, we consider the cardio
test program that is part of Cingulata and consists of two files:
-
cardio.cxx
- The program's logic. It uses theBitTracker
class to record operations to be transformed into their equivalent circuit at run-time. -
run.sh.in
- A script template that automates key generation, input data encryption, execution, and decryption.
During the cmake
step, the Makefiles are created that contain the commands required for building and optimizing the circuit. Also, the run.sh.in
script template is configured, i.e., placeholder variables (e.g., paths) that are formatted as @KEY_NAME@
are replaced by concrete values, resulting in the executable file run.sh
.
Executing the make
command starts the actual build process. Essential part of it is building the helper utilities (apps/
directory) for encoding data into binary numbers (helper
), en- and decryption (encrypt
/decrypt
), key generation (generate_keys
), and homomorphic evaluation (dyn_omp
).
Furthermore, the program cardio.cxx
is built and automatically executed, resulting in a circuit file bfv-cardio.blif
. Thereafter, a Python script is executed that invokes the ABC circuit optimizer on that circuit, resulting in an optimized circuit bfv-cardio-opt.blif
. A helper script (selectParams.sh
) then uses CinguParam to derive suitable parameters for the circuit. These are stored in the fhe_params.xml
file.
After the build process finished, the user can execute the run.sh
file to run the program:
This first generates the required FHE keys – a public key (fhe_key.pk
), a private key (fhe_key.sk
), and an evaluation key (fhe_key.evk
).
Then, the input data that is specified in the same file is encrypted using the hard-coded Kreyvium keystream and written into the input/
directory that stores the circuit inputs.
This directory contains a ciphertext file for each bit of an input parameter, e.g., i:ks_X_Y
denotes the Y-th bit of the X-th input parameter.
Afterward, the program is homomorphically executed over the encrypted inputs and the encrypted result is written into the output/
directory in a bit-encoded style, similar as the input.
Finally, the execution's result is decrypted and printed to the screen.
- Home
- Compilers & Optimizations
- Libraries
- Benchmark Programs
- Implementation Docs