Skip to content

The Intel Homomorphic Encryption (HE) toolkit is the primordial vehicle for the continuous distribution of the Intel HE technological innovation to users. The toolkit has been designed with usability in mind and to make it easier for users to evaluate and deploy homomorphic encryption technology on the Intel platforms.

License

Notifications You must be signed in to change notification settings

tgonzalez89-intel/he-toolkit

 
 

Repository files navigation

Intel Homomorphic Encryption Toolkit

The Intel Homomorphic Encryption (HE) toolkit is designed to make it fast and easy to evaluate homomorphic encryption technology on Intel® Processors using libraries, such as Intel HEXL, optimized to take advantage of the newest Intel hardware features. Additionally, the Intel HE-Toolkit is a great starting point for people new to homomorphic encryption, offering sample kernels showing multiple examples of how the libraries can be used to implement common mathematical operations using Microsoft SEAL, PALISADE, or HElib. In addition, there are example applications which demonstrate how HE technology can be used to create secure applications.

Contents

Dependencies

The toolkit has been tested on Ubuntu 20.04

Must have dependencies include:

cmake >= 3.13
git
pthread
patchelf
m4
g++ >= 10.0 or clang >= 10.0
python >= 3.5
virtualenv

Dependencies required per library include:

autoconf (PALISADE)
gmp >= 6.2.1 (HElib)
NTL >= 11.5.1 (HElib)

Instructions

There are currently two methods for building the toolkit project.

Docker Build (Recommended)

The recommended method is to use the Docker build and installation which builds the toolkit in its entirety including all HE libraries in a self-contained docker container running Ubuntu 20.04. See here for a detailed description on the usage and components of this build.

Native Build

Alternatively, one can build the toolkit natively using the following commands

export HE_SAMPLES=$(pwd)/he-samples
cd $HE_SAMPLES
cmake -S . -B build
cmake --build build -j

This will build the toolkit project with the default settings. The toolkit will download and build all three HE libraries automatically with HEXL enabled.

Note: You will be responsible for installing all of the required dependencies.

It is possible to pass additional options, for example:

 -DENABLE_PALISADE=ON
 -DENABLE_SEAL=ON
 -DENABLE_HELIB=OFF

to enable/disable building of certain HE libraries. The following table contains the current CMake options, default values are in bold.

CMake options Values Comments
ENABLE_PALISADE ON/OFF Enable PALISADE
ENABLE_SEAL ON/OFF Enable SEAL
ENABLE_HELIB ON/OFF Enable HElib
ENABLE_INTEL_HEXL ON/OFF Enable Intel HEXL
ENABLE_ADDRESS_SANITIZER ON/OFF Compiles and link with Address Sanitizer
ENABLE_THREAD_SANITIZER ON/OFF Compiles and link with Thread Sanitizer
ENABLE_UB_SANITIZER ON/OFF Compiles and link with Undefined Behaviour Sanitizer
SEAL_PREBUILT ON/OFF Use a pre-built installation of SEAL
PALISADE_PREBUILT ON/OFF Use a pre-built installation of PALISADE
HELIB_PREBUILT ON/OFF Use a pre-built installation of HElib

Note: If using a pre-built library then you may need to use the option -D<SEAL|PALISADE|HELIB>_HINT_DIR=<path-to-installation> if you have installed them in a non-default location.

Kernels

Located in he-samples is a collection of software components built on Microsoft SEAL and PALISADE comprising sample kernels for operations performed homomorphically and example applications. The HE Samples are designed to enable quicker evaluation of HE on Intel platforms, serve as a learning tool for how to implement operations in different HE libraries, and provide examples of how these operations can be used to build applications based on HE technology for different use cases.

Sample kernels

The sample kernels are for complex HE operations, requiring multiple API calls such as Matrix Multiplication and Vector Dot Product. See the README for instructions.

Test sample kernels

The unit tests are a selection of unit tests meant for verifying the accuracy of the various sample kernels included in this project. See the README for more information.

Examples

The examples directory includes example applications built using HE technology. The primary purpose of these examples is to serve as a showcase of different use cases which can be implemented using HE. Moreover, these can be used as learning references and starting points for further development. The toolkit currently includes the following examples listed below.

Secure Query

The secure query example shows how it is possible to implement a key-value database using HE. This allows a client to perform lookups of values in the database without exposing the query to the server hosting the database and optionally the key-value pairs in the database as well. The secure query example is implemented using the SEAL BFV scheme. See the README for more details and instructions on how to run this program.

Logistic Regression

The transposed logistic regression example presents a scalable and fast method of logistic regression inference in HE. Using the SEAL CKKS scheme, the example will encrypt the model (bias and weight) and takes batches of encrypted data samples to perform the inference all within the HE domain. See the README for usage information.

Contributing

At this time, Intel HE Toolkit does not accept external contributions. We encourage feedback and suggestions via GitHub Issues as well as via GitHub Discussions.

For Intel developers, ensure the pre-commit config is active prior to contributing, i.e. run

pre-commit install
pre-commit run --all-files

and make sure all pre-commit checks pass.

Contributors

The Intel contributors to this project, sorted by last name, are

About

The Intel Homomorphic Encryption (HE) toolkit is the primordial vehicle for the continuous distribution of the Intel HE technological innovation to users. The toolkit has been designed with usability in mind and to make it easier for users to evaluate and deploy homomorphic encryption technology on the Intel platforms.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 81.9%
  • CMake 7.7%
  • Jupyter Notebook 4.0%
  • Python 3.3%
  • Shell 3.1%