PALISADE (software)
From Wikipedia, the free encyclopedia
PALISADE is an open-source cross platform software library that provides implementations of lattice cryptography building blocks and homomorphic encryption schemes.[2]
| PALISADE | |
|---|---|
| Developers | New Jersey Institute of Technology, Duality Technologies, Raytheon BBN Technologies, MIT, University of California, San Diego and other contributors[1] |
| Initial release | July 15, 2017 |
| Stable release | 1.11.9
/ December 3, 2022 |
| Written in | C++ |
| Platform | Microsoft Windows, MacOS, Linux |
| License | BSD 2-Clause |
| Website | palisade-crypto |
| Repository | gitlab |
History
PALISADE adopted the open modular design principles of the predecessor SIPHER software library from the DARPA PROCEED program. SIPHER development began in 2010, with a focus on modular open design principles to support rapid application deployment over multiple FHE schemes and hardware accelerator back-ends, including on mobile, FPGA and CPU-based computing systems. PALISADE began building from earlier SIPHER designs in 2014, with an open-source release in 2017 and substantial improvements every subsequent 6 months.
PALISADE development was funded originally by the DARPA PROCEED and SafeWare programs, with subsequent improvements funded by additional DARPA programs, IARPA, the NSA, NIH, ONR, the United States Navy, the Sloan Foundation and commercial entities such as Duality Technologies. PALISADE has subsequently been used in commercial offerings, such as by Duality Technologies who raised funding in a Seed round[3] and a later Series A round[4] led by Intel Capital.
In 2022 OpenFHE was released as a fork that also implements CKKS bootstrapping.
Features
PALISADE includes the following features:[5]
- Post-quantum public-key encryption
- Fully homomorphic encryption (FHE)
- Brakerski/Fan-Vercauteren (BFV) scheme[6][7] for integer arithmetic with RNS optimizations[8][9][10]
- Brakerski-Gentry-Vaikuntanathan (BGV) scheme[11] for integer arithmetic with RNS optimizations[12]
- Cheon-Kim-Kim-Song (CKKS) scheme[13] for real-number arithmetic with RNS optimizations[14][15][16][17]
- Ducas-Micciancio (FHEW) scheme[18] for Boolean circuit evaluation with optimizations[19]
- Chillotti-Gama-Georgieva-Izabachene (TFHE)[20] scheme for Boolean circuit evaluation with extensions[19]
- Multiparty extensions of FHE
- Threshold FHE for BGV, BFV, and CKKS schemes[21]
- Proxy re-encryption for BGV, BFV, and CKKS schemes[22]
- Digital signature[23]
- Identity-based encryption[23]
- Ciphertext-policy attribute-based encryption[24]
Availability
There are several known git repositories/ports for PALISADE:
C++
- PALISADE Stable Release (official stable release repository)
- PALISADE Preview Release (official development/preview release repository)
- PALISADE Digital Signature Extensions
- PALISADE Attribute-Based Encryption Extensions (includes identity-based encryption and ciphertext-policy attribute-based encryption)
JavaScript / WebAssembly
- PALISADE WebAssembly (official WebAssembly port)
Python
- Python Demos (official Python demos)
FreeBSD
- PALISADE (FreeBSD port)