K-miran / HELR

Secure Logistic Regression based on Homomorphic Encryption

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

HELR

HELR is a software project for performing a logistic regression training on encrypted data (Secure Logistic Regression based on Homomorphic Encryption: Design and Evaluation (https://medinform.jmir.org/2018/2/e19/))

Setting up HELR library

Dependencies

Our library requires a c++ compiler and the following libraries:

  • GMP(GNU Multi-Precision library), which is available at https://gmplib.org,

  • NTL(ver. 10.5.0), which is available at http://www.shoup.net/ntl/, (with pThread)

  • HEAAN, which is an implementation of the paper "Homomorphic Encryption for Arithmetic of Approximate Numbers" (https://eprint.iacr.org/2016/421.pdf). We refered to the underlying HE library in the "src" folder. You can build the libarary “libheaan.a" by typing "$make all" in the "/src" directory.

Installing HELR library

HELR is easy to configure and build in Linux and macOS. You can then install our library by the following work with command line tools:

make new

Running a test source code

You run a test program Test_HELR.cpp with a filename and a degree of approximating polynomial of the sigmoid function. For example, you can write:

g++ -std=c++11 -O2 -I/usr/local/include -pthread Test_HELR.cpp src/libheaan.a libHELR.a -o foo -L/usr/local/lib -lntl -lgmp -lm
./foo data/edint.txt 3 

In particular, our program supports the evaluation of the gradient descent algorithm based on polynomial of degree 3 or degree 7 with several optimizations.

About

Secure Logistic Regression based on Homomorphic Encryption

License:MIT License


Languages

Language:C++ 99.6%Language:Makefile 0.4%